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Abstract 

This paper addresses the problem of detecting and characterizing lo- 
cal variability in time series and other forms of sequential data. The 
goal is to identify and characterize statistically significant variations, at 
the same time suppressing the inevitable corrupting observational errors. 
. We present a simple nonparametric modeling technique and an algo- 

1 rithm implementing it — an improved and generalized version of Bayesian 

Blocks Scargle 1998] — that finds the optimal segmentation of the data 
in the observation interval. The structure of the algorithm allows it 
1 to be used in either a real-time trigger mode, or a retrospective mode. 

Maximum likelihood or marginal posterior functions to measure model 
fitness are presented for events, binned counts, and measurements at ar- 
bitrary times with known error distributions. Problems addressed include 
■ those connected with data gaps, variable exposure, extension to piece- 

» I " wise linear and piecewise exponential representations, multi-variate time 

, series data, analysis of variance, data on the circle, other data modes, 

and dispersed data. Simulations provide evidence that the detection effi- 
ciency for weak signals is close to a theoretical asymptotic limit derived 
by [Arias-Castro, Donoho and Huo 2003 . In the spirit of Reproducible 
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Research Donoho et al. (2008) all of the code and data necessary to re- 



produce all of the figures in this paper are included as auxiliary material. 

Keywords: time series, signal detection, triggers, transients, Bayesian 
analysis 
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"The line is similar to a length of time, and as 
the points are the beginning and end of the line, 
so the instants are the endpoints of any given ex- 
tension of time." Leonardo da Vinci, Codex Arundel, 
folio 190v., c. 1500 A.D. |Capra 2007 . 
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1 The Data Analysis Setting 



This paper describes a method for nonparametric analysis of time 
series data to detect and characterize structure localized in time. 
Nonparametric methods seek generic representations, in contrast to 
fitting of models to the data. By local structure we mean light-curve 
features occupying sub-ranges of the total observation interval, in 
contrast to global signals present all or most of the time (e.g. pe- 
riodicities) for which Fourier, wavelet, or other transform methods 
are more appropriate. The goal is to separate statistically signif- 
icant features from the ever-present random observational errors. 
Although phrased in the time-domain the discussion throughout is 
applicable to measurements sequential in wavelength, spatial quan- 
tities, or any other other independent variable. 

This setting leads to the following desiderata: The ideal algo- 
rithm would impose as few preconditions as possible, avoiding as- 
sumptions about smoothness or shape of the signal that place a pri- 
ori limitations on scales and resolution. The algorithm should han- 
dle arbitrary sampling (i.e., not be limited to gapless, evenly spaced 
data) and large dynamic ranges in amplitude, time scale and signal- 
to-noise. For scientific data mining applications and for objectivity, 
the method should be largely automatic. To the extent possible it 
should suppress observational errors while preserving whatever valid 
information lies in the data. It should be applicable to multivari- 
ate problems. It should incorporate variation of the exposure or 
instrumental efficiency during the measurement, as well auxiliary, 
extrinsic information, e.g. spectral or color information. It should 
be able to operate both retrospectively (analyze all the data after 
they are collected) and in a real-time fashion that triggers on the 
first significant variation of the signal from its background level. 

The algorithm described here achieves considerable success in 
each of these desired features. In a simple and easy-to-use com- 
putational framework it represents the structure in the signal in a 
form handy for further analysis and the estimation of physically 
meaningful quantities. It includes an automatic penalty for model 
complexity, thus solving the vexing problems associated with model 
comparison in general and determining the order of the model in par- 
ticular. It is exact, not a greed]^ approximation as in |Scargle 1998 



1 This term refers to algorithms that greedily make optimal improvements at each iteration 
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Versions of this algorithm have been used in various applications, 



such as Qin et al. 2012 Norris Gehrels and Scargle 2010 Norris Gehrels and Scargle 2011 



Way Gazis and Scargle 2011 . 



The following sections discuss, in turn, the basis of segmenta- 
tion analysis ( §l.ip . the piecewise constant model adopted in this 
work ( §1.2p . extensions to piecewise linear and piecewise exponen- 
tial models ( §1.3p . the types of data that the algorithm can accept 
(§ §1.51 and II. 6p . data gaps ( §1.7p . exposure variations ( §1.8[) . a pa- 
rameter from the prior on the number of blocks ( §1.9[) . generalities 
of optimal segmentation of data into blocks (§2]), some error analysis 
( §2.8p . a variety of block fitness functions ($3]), and sample applica- 
tions (§E]). Appendices present some MatLab © code, some miscel- 
laneous results, and details of other data modes, including dispersed 
data ( §C.8p . Ancillary files are available providing scripts and data 
in order to reproduce all of the figures in this paper. 

1.1 Optimal Segmentation Analysis 

The above considerations point toward the most generic possible 
nonparametric data model, and have motivated the de velopment of 



data segmentation and change-point methods - see e.g. O Ruanaidh and Fitzgerald 1996 



Scargle 19 98 . These methods represent the signal structure in terms 
of a segmentation of the time interval into blocks, with each block 
containing consecutive data elements satisfying some well defined 
criterion. The optimal segmentation is that which maximizes some 
quantitative expression of the criterion - for example the sum over 
blocks of a goodness-of-fit of a simple model of the data lying in 
each block. 

These concepts and methods can be applied in surprisingly gen- 
eral, higher dimensional contexts. Here, however, we concentrate 
on one-dimensional data ordered sequentially with respect to time 
or some other independent variable. In this setting segmentation 
analysis is often called change-point detection, since it implements 
models in which a signal's statistical properties change discontinu- 
ously at discrete times but are constant in the segments between 
these change-points (see §2.5p . 



but are not guaranteed to converge to a globally optimal solution. 
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1.2 The Piecewise Constant Model 

It is remarkable that all of the desiderata outlined in the previ- 
ous section can be achieved in large degree by optimal fitting of a 
piecewise-constant model to the data. The range of the independent 
variable (e.g. time) is divided into subintervals (here called blocks) 
generally unequal in size, in which the dependent variable (e.g. in- 
tensity) is modeled as constant within errors. Of all possible such 
"step-functions" this approach yields the best one by maximizing 
some goodness-of-fit measure. 

Defining the times ending one block and starting the next as 
change-points, the model of the whole observation interval contains 
these parameters: 

(1) N cp : the number of change-points 

(2) t c £: the change-point starting block k 

(3) X^: the signal amplitude in block k 

for /c = 1,2,... N cp + lE The key idea is that the blocks can be 
treated independently, in the sense that a block's fitness depends 
on its data only. Our simple model for each block has effectively 
two parameters. The first represents the signal amplitude, and is 
treated as a nuisance parameter to be determined after the change- 
points have been located. The second parameter is the length of the 
interval spanned by the block. (The actual start and stop times of 
this interval are needed for piecing blocks together to form the final 
signal representation, but not for the fitness calculation.) 

How many blocks? A key issue is how to determine the number 
of blocks, Nbiocks = N cp + 1. Nonparametric analysis invariably 
involves controlling in one way or another the complexity of the 
estimated representation. Typically such regulation is considered 
a trade-off of bias and variance, often implemented by adjusting a 
smoothing parameter. 

But smoothing is one of the very things we are trying to avoid. 
The discontinuities at the block edges are regarded as assets, not 

2 There is one more block than there are change-points: The first datum is always consid- 
ered a change-point, marking the start of the first block, and is therefore not a free parameter. 
If the last datum is a change-point, it denotes a block consisting solely of that datum. 
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liabilities to be smoothed over. So rather than smooth we influ- 
ence the number of blocks by defining a prior distribution for the 
number of blocks. Adjusting a parameter controlling the steepness 
of this prior establishes relative probabilities of smaller or larger 
numbers of blocks. In the usual fashion for Bayesian model se- 
lection in cases with high signal-to-noise Nuocks is determined by 
the structure of the signal; with lower signal-to-noise the prior be- 
comes more and more important. In short, we are regulating not 
smoothness but complexity, much in the way that wavelet denois- 
ing |Donoho and Johnstone 1998] operates without smoothing over 
sharp features as long as they are supported by the data. The 
adopted prior and the determination of its parameter are discussed 
in §1.91 below. 

This segmented representation is in the spirit of nonparametric 
approximation and not meant to imply that we believe the signal 
is actually discontinuous. The sometimes crude and blocky appear- 
ance of this model may be awkward in visualization contexts, but for 
deriving physically meaningful quantities it is not. Blocky models 
are broadly useful in signal processing |Donoho 1994] and have sev- 
eral motivations. Their simplicity allows exact treatment of various 
quantities, such as the likelihood. We can optimize or marginalize 
the rate parameters exactly, giving simple formulas for the fitness 
function (see §3] and Appendix C. EfU]) . And in many applications the 
estimated model itself is less important than quantities derived from 
it. For example, while smoothed plots of pulses within gamma-ray 
bursts make pretty pictures, one is really interested in pulse loca- 
tions, lags, amplitudes, widths, rise and decay times, etc. All these 
quantities can be determined directly from the locations, heights 
and widths of the blocks - accurately and free of any smoothness 
assumptions. 



1.3 Piecewise Linear and Exponential Models 

Some researchers have applied segmentation methods with other 
block representations. For example piecewise linear models have 
been used in measuring similarity among time series and in pat- 
tern matching Lin, Keogh, Lonardi and Chiu 2003] and to repre- 
sent time series generated by non-linear processes |Tong 19 90 . While 
such models may seem better than discontinuous step functions, 
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their improved flexibility is somewhat offset by added complexity of 
the model and its interpretation. Note further that if continuity is 
imposed at the change-points, a piecewise linear model has essen- 
tially the same number of degrees of freedom as does the simpler 
piecewise constant model. 

We mention two such generalizations, one modeling the signal as 
linear in time across the block: 

x{t) = X{l + a{t-t Sd )) (1) 

and the second as exponential: 

x(t) = Ae a (*-*fid) . (2) 

In both cases A is the signal strength at the fiducial time and 
the coefficient a determines the rate of variation over the block. 
Such models may be useful in spite of the caveats mentioned above 
and the added complexity of the block fitness functions. Hence we 
provide some details in Appendix C, § §C.9l and lC.10l 



1.4 Histograms 

For event data the piecewise constant representation can be inter- 
preted as a histogram of the measured values - one in which the 
bins are not fixed ahead of time and are free to be unequal in size 
as determined by the data. In this context the time order of the 
measurements is irrelevant. Once one determines the parameter in 
the prior on the number of bins, ncp_prior, one has an objective 
histogram procedure in which the number, individual sizes, and lo- 
cations of the bins are determined solely and uniquely by the data. 



1.5 Data Modes 

The algorithms developed here can be used with a variety of types 
of data, often called data modes in instrumentation contexts. An 
earlier paper Scargle 1998 described several, with formulas for the 
corresponding fitness functions. Here we discuss data modes in a 
broader perspective. It is required that the measurements provide 
sufficient information to determine which block they belong to and 
then to compute the model fitness function for the block (cf . §2.3p . 



8 



Almost any physical variable and any measurement scheme for it, 
discrete or quasi-continuous, can be accommodated. In the simple 
one dimensional case treated here, the independent variable is time, 
wavelength, or some other quantity. The data space is the domain 
of this variable over which measurements were made - typically an 
interval, possibly interrupted by gaps during which the measuring 
system was not operating. 

The measured quantity can be almost anything that yields infor- 
mation about the target signal. The three most common examples 
emphasized here are: (a) times of events (often called time-tagged 
event data, or TTE), (b) counts of events in time bins, and (c) mea- 
surements of a quasi-continuous observable at a sequence of points 
in time. For the first two cases the signal of interest is the event 
rate, proportional to the probability distribution regulating events 
which occur at discrete times due to the nature of the astrophys- 
ical process and/or the way it is recorded. We call case (c) point 
measurements, not to be confused with point data (also called event 
data). These modes have much in common, as they all comprise 
measurements that can be at any time; what differentiates them is 
their statistics, roughly speaking Bernoulli, Poisson, and Gaussian 
(or perhaps some other) respectively. 

The archetypal example of (a) is light collected by a telescope and 
recorded as a set of detection times of individual photons to study 
source variability. Case (b) is similar, but with the events collected 
into bins - which do not have to be equal or evenly spaced. Case 
(c) is common when photons are not detected individually, such as 
in radio flux measurements. In all cases it is useful to represent the 
measurements with data cells, typically one for each measurement 
(see §2.2p . In principle mixtures of cells from different data types 
can be handled, as described in the next section. 

1.6 Mixed Data Modes 

Our algorithm can analyze mixtures of any data types within a single 
time series. For example the data stream could consist of arbitrary 
combinations of cells of the three types defined above - measured 
values, counts in bins and events - with or without overlap in time 
among the various data modes. In regions of overlap the block 
representation would be based on the combined data; otherwise it 
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would represent block structures supported by the corresponding 
individual data modes. In such applications the cost function must 
refer to a common signal amplitude parameter, possibly including 
normalization factors to account for differences in the measurement 
processes. 

A related concept is that of multivariate time series, usually re- 
ferring to concurrent observations from different telescopes. The 
distinction between this concept and mixed data modes is largely 
semantic. Hence we leave implimentation details to §4.21 

1.7 Gaps 

In some cases there are subintervals over which no data can be 
obtained. For example there may be random interruptions such as 
detector malfunction at unpredictable but known periods of time, 
or regular interruptions as the Earth periodically blocks the view 
of an object from an orbiting space observatory. (Of course this 
case is very different from intervals in which no events happened to 
be detected, due to low event rate, or in which one simply did not 
happen to make point measurements. 

Such data gaps have a nearly invisible affect on the algorithm, 
fundamentally due to the fact that it operates locally in the time 
domain. For event data all that matters is the live time during the 
block, i.e. the time over which data could have been registered. 
Other than correcting the total time span of any putative block 
containing data gaps by subtracting the corresponding dead time, 
gaps can be handled by ignoring them. Operationally one simply 
treats the data right after a gap as immediately following the data 
right before it (and not delayed by the length of the gap). Think of 
this as squeezing the interval to eliminate the gaps, carrying out the 
analysis as if no gaps are present, and then un-doing the squeezing 
by restoring the original times. This procedure is valid because event 
independence means that the fitness of a block depends on only its 
total live-time and the events within it. 

For event data this squeezing can be implemented by subtracting 
from each event time the sum of the lengths of all the preceding gaps. 
One small detail concerns the points just before and just after a gap. 
One might think their time intervals should be computed relative to 
the gap edges. But it follows from the nature of independent events 
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(Appendix B, §|B]) that they can be computed as though the gap did 
not exist. 

The only other subtlety lies in interpreting the model in and 
around gaps. There are two possibilities: a given gap (a) may lie 
completely within a block or (b) it may separate two blocks. Case 
(a) can be taken as evidence that the event rates before and after the 
gap are deemed the same within statistical fluctuations. Case (b) on 
the other hand implies that the event rate did change significantly. 

Of course the gaps must be restored for display and other post- 
processing analysis. Think of this as un-squeezing the data so that 
all blocks appear at their correct locations in time. Keeping in mind 
that there is no direct information about what happened during 
unobserved intervals, plots should probably include some indication 
that rates within gaps are unknown or uncertain, such as by use of 
dotted lines or shading in the gap for case (a) or leaving the gap 
interval completely blank in case (b). 

For the case of point measurements the situation is different. In 
one sense there are no gaps at all, and in another sense the entire 
observation interval consists of many gaps separating tiny intervals 
over which the measurements were actually made. One is hard- 
pressed to make a statistical distinction between various reasons 
why there is not a measurement at a given time - e.g. detector 
and weather problems, or simply a choice as to how to allocate 
observing time (a choice that may even depend on the results of 
analyzing previous data). Basically the blocks in this case represent 
intervals where whatever measurements were made in the interval 
are consistent with a signal that is constant over that interval. 

Note that things would be different if one wanted to define a 
fitness function dependent on the total length of the block, not just 
its live time. This would arise for example if a prior on the block 
length were imposed. Such possibilities will not be discussed here. 

1.8 Exposure Variations 

In some applications the effective instrument response is not con- 
stant. The measurements then reflect true source variations modi- 
fied by changes in overall throughput of the detection system. We 
use the term exposure for any such effect on the detected signal - 
e.g. detector efficiency, telescope effective area, beam pattern and 
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point spread function effects. Exposure can be quantified by the 
ratio of the expected signal with and without any such effects. It 
may be calculable from properties of the observing system, deter- 
mined after the fact through some sort of calibration procedure, or 
a combination of the two. Here we assume that this ratio is known 
and expressed as a number e„, typically with < e n < 1, for data 
cell n. 

The adjustment for exposure is simple, namely change the pa- 
rameter representing the observed signal amplitude in the likelihood 
to what it would have been if the exposure had been unity. First 
compute the exposure e n for data cell n. Then increase by the fac- 
tor l/e n whatever quantity in the data cell represents the measured 
signal intensity. Specifically, for time-tagged event data this pa- 
rameter is the reciprocal of the interval of the corresponding data 
cell: 1/At n (see eq. (j201) ). which is then replaced with l/(e„At n ). 
For bin counts the bin size can be multiplied by e n or equivalently 
the count by l/e n . For point measurements multiply the amplitude 
measurement by l/e n (and adjust any observational error parame- 
ters accordingly). In all cases the goal is to represent the data as 
closely as possible to what it would have been if the exposure had 
been constant. Of course this restoration is not exact in individual 
cases, but is correct on average. 

For TTE data the fact that interval At n as we define it in eq. 
(1201) depends on the times of two different events (just previous to 
and just after the one under consideration) may seem to pose a 
problem. The exposures of these events will in general be different, 
so what value do we use for the given event? The comforting answer 
is that the only relevant exposure is that for the given event itself. 
For consider the interval from the previous to the current time, 
namely t n — t n -\. Here t n _i is regarded as simply a fiducial time 
and the distribution of this interval is given by eq. fH7|) with A 
the true rate adjusted by the exposure for event n, by the principle 
described in §B.5I just after this equation. Similarly by a time- 
reversal invariance argument the distribution of the interval to the 
subsequent event, namely t n+ i — t n , also depends on only the same 
quantity. In summary event independence (Appendix C, $C]) yields 
the somewhat counterintuitive fact that the probability distribution 
of At n = (t n+ i— t n _i)/2 of the interval surrounding event n depends 
on only the effective event rate for event n. 
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1.9 Prior for the Number of Blocks 



Earlier work |Scargle 1998 did not assign an explicit prior probabil- 
ity distribution for the number of blocks, i.e. the parameter Nbi oc ks- 
This omission amounts to using a flat prior, but in many contexts 
it is unreasonable to assign the same prior probability to all values. 
In particular, in most settings it is much more likely a priori that 
Nbiocks « N than that Nuocks ~ N. For this reason it is desirable 
to impose a prior that assigns smaller probability to a large number 
of blocks, and we adopt this geometric prior [Coram 2 002J: 

P(N blocks ) = P Ql N ^ (3) 

for < Nuocks < N, and zero otherwise since N b i ocks cannot be 
negative or larger than the number of data cells. The normalization 
constant P is easily obtained, giving 

P(N bl o C ks) = 1 * (4) 

Through this prior the parameter 7 influences the number of blocks 
in the optimal representation - a number of some importance since 
it affects the visual appearance of the representation and to a lesser 
extent the values of quantities derived from it. This form for the 
distribution dictates that finding k + 1 blocks is less likely by the 
constant factor 7 than is finding k blocks. In almost all applications 
7 will be chosen < 1 to express that a smaller number of blocks is a 
priori more likely than a larger number. 

In principle the choice of a prior and the values of its param- 
eters expresses one's prior knowledge in a specific problem. The 
convenient geometric prior adopted here has proven to be generic 
and flexible, and its parameterization is simple and straightforward. 
These properties are appropriate for a generic analysis tool meant 
for a wide variety of applications. One can think of selecting 7 as a 
simple way of adjusting the amount of structure in the block repre- 
sentation of the signal. It is specifically not a smoothing parameter 
but is analogous to one. 

The expected number of blocks follows from eq. ([3]) 

N N'y^ 1 + 1 1 

< N blocks > = P N biocksl Nhlocka = N+1 _ + — — (5) 

N h ,nnk,=0 1 117 
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Note that the actual number of blocks is a discontinuous, monotonic 
function of 7, and because its jumps can be > 1 it is not generally 
possible to force a prescribed number by adjusting this parameter. 

The above prior is not the only one possible and different forms 
may be useful in some applications. But Eq. fl3]) is very convenient 
to implement, since with the fitness equal to the log of the posterior, 
one only needs to subtract the constant — log 7 (called ncp_prior 
in the MatLab code and in the discussion of computational issues 
below) from the fitness of each block. Determining the value to use 
in applications is discussed in §2.71 below. 

2 Optimum Segmentation of Data on an Inter- 
val 

Piecewise constant modeling of sequential measurements on a time 
interval T is most conveniently implemented by seeking an optimal 
partition of the ordered set of data cells within T. In this special 
case of segmentation the segments cover the whole set with no over- 
lap between them (Appendix B). Segmentations with overlap are 
possible, for example in the case of correlated measurements, but 
are not considered here. One can envision our quest for the optimal 
segmentation as nothing more than finding the best step-function, 
or piecewise constant model, fit to the data - defined by maximizing 
a specific fitness measure as detailed in §2.41 

We introduce our algorithm in a somewhat abstract setting be- 
cause the formalism developed here applies to other data analy- 
sis problems beyond time series analysis. It implements Bayesian 
Blocks or other ID segmentation ideas for any model fitness function 
that satisfies a simple additivity condition. It improves the previous 
approximate segmentation algorithm |Scargle 1 998 by achieving an 
exact, rigorous solution of the multiple change-point problem, guar- 
anteed to be a global optimum, not just a local one. 

The rest of this section describes how the model is structured for 
effective solution of this problem, while details on the quantity to 
be optimized are deferred to the next section. 

2.1 Partitions 

Partitions of a time interval T are simply collections of non-overlapping 
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blocks (defined below in §2.3j) . denned by specifying the number of 
its blocks and the block edges: 

CP(f) = {Nuocks] n k , k = 1, 2, 3, . . . Nuocks} ■ (6) 

where the are indices of the data cells ( §2.2p defining times called 
change-points (see §2.5p . 

Appendix B gives a few mathematical details about partitions, 
including justification of the restriction of the change-points to coin- 
cide with data points and the result that the number of possible par- 
titions (i.e. the number of ways N cells can be arranged in blocks) 
is 2 N . This number is exponentially large, rendering an explicit 
exhaustive search of partition space utterly impossible for all but 
very small N. Our algorithm implicitly performs a complete 
search of this space in time of order iV 2 , and is practical even 
for N ~ 1, 000, 000, for which approximately lO 300,000 partitions are 
possible. The beauty of the algorithm is that it finds the optimum 
among all partitions without an exhaustive explicit search, which is 
obviously impossible for almost any value of N arising in practice. 

2.2 Data Cells 

For input to the algorithm the measurements are represented with 
data cells. For the most part there is one cell for each measure- 
ment, although in the case of TTE data two or more events with 
identical time-tags may be combined into a single cell. A conve- 
nient data structure is an array containing the cells ordered by the 
measurement times. 

Specification of the contents of the cells must meet two require- 
ments. First they must include time information allowing determi- 
nation of which cells lie in a block given its start and stop times. 
Post-processing steps such as plotting the blocks may in addition 
use the actual times, either absolute or relative to a specified origin. 

The other requirement is that the fitness of a block can be com- 
puted from the contents of all the cells in it ( §2.4[ §3])- For the three 
standard cases the relevant data are roughly speaking: (a) intervals 
between events ( §3.ip . (b) bin sizes, locations and counts ( §3.2p . and 
(c) measured values augmented by a quantifier of measurement un- 
certainty ( §3.3p . These same quantities enable construction of the 
resulting step function for post-processing steps such as computing 
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signal parameters. 



2.3 Blocks of Cells 

A block is any set of consecutive cells, either an element of the op- 
timal representation or a candidate for it. Each block represents a 
subinterval (within the full range of observation times) over which 
the amplitude of the signal can be estimated from the contents of 
its cells ( §2.2p . A block can be as small as one cell or as large as all 
of the cells. 

Our time series model consists of a set of blocks partitioning the 
observations. All model parameters are constant within each block 
but undergo discrete jumps at the change-points ( §2.5[) marking the 
edges of the blocks. The model is visualized by plotting rectangles 
spanning the intervals covered by the blocks, each with height equal 
to the signal intensity averaged over the interval. The concept of 
fitness of a block is fundamental to everything else in this paper. As 
we will see in the next section the fitness of a partition is the sum 
of the fitnesses of the blocks comprising it. 

2.4 Fitness of Blocks and Partitions 

Since the goal is to represent the data as well as possible within a 
given class of models, we maximize a quantity measuring the fitness 
of models in the given class, here the class of all piecewise constant 
models. Alternatively, one can minimize an error measure. Both op- 
erations are called optimization. The algorithm relies on the fitness 
being block-additive, i.e. 



where F[CP(T)] is the total fitness of the partition 7 of interval T, 
and f{Bk) is the fitness of block k. The latter can be any convenient 
measure of how well a constant signal represents the data within 
the block. Typically additivity results from independence of the 
observational errors. We here ignore the possibility of correlated 
errors, which could make the fitness of one block depend on that of 
its neighbors. Remember correlation of observational errors is quite 
separate from correlations in the signal itself. 




(7) 



k=l 
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All model parameters are marginalized except the n k specifying 
block edges. Then the total fitness depends on only these remaining 
parameters - i.e. on the detailed specification of the partition by 
indicating which cells fall in each of its blocks. The best model is 
found by maximizing F over all possible such partitions. 

2.5 Change-points 

In the time series literature a point at which a statistical model 
undergoes an abrupt transition, by one or more of its parameters 
jumping instantaneously to a new value, is called a change-point. 
This is exactly what happens at the edges of the blocks in our model. 
In principle change-points can be at arbitrary times. However, fol- 
lowing the data cell representation and without any essential loss 
of generality they can be restricted to coincide with a data point 
(Appendix B; gBJ. 

A few comments on notation are in order. We take blocks to start 
at the data cell identified by the algorithm as a change-point and 
to end at the cell previous to the subsequent change-point. A slight 
variation of this convention is discussed below in §4.41 in connection 
with allowing the possibility of empty blocks in the context of event 
data. One might adopt other conventions, such as apportioning the 
change-point data cell to both blocks, but we do not do so here. 
Even though the first data cell in the time series always starts the 
first block, our convention is that it is not considered a change-point. 
In the code presented here the first change-point marks the start of 
the second block. For k > 1 the k-th block starts at index n k _i and 
ends at rife — 1. The first block always starts with the very first data 
cell. The last block always terminates with the very last data cell. 
If the last cell is a change-point, it defines a block consisting of only 
that one cell. The set of change-points is empty if the best model 
consists of a single block, meaning that the time series is sensibly 
constant over the whole observation interval. The number of blocks 
is one greater than the number of change-points. 
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2.6 The Algorithm 

We now outline the basic algorithm yielding the desired optimum 
partitions. The details of this dynamic programming approach 
[Bellman 19611 |Hubert, Arabie, and Meulman 200T| |Dreyfus 2002] 



are in [Jackson et al. 2005] . It follows the spirit of mathematical 
induction: beginning with the first data cell, at each step one more 
cell is added. The analysis makes use of results stored from all 
previous steps. Remarkably the algorithm is exact and yields the 
optimal partition of an exponentially large space in time of order 
N 2 . The iterations normally continue until the whole interval has 
been analyzed. However its recursive nature allows the algorithm 
to function in a trigger mode, halting when the first change-point is 
detected ( 90]) . 

Let IP opt (i?) denote the optimal partition of the first R cells. In 
the starting case R = 1 the only possible partition (one block con- 
sisting of the first cell by itself) is trivially optimal. Now assume we 
have completed step R, identifying the optimal partition CP° p *(i?). 
At this (and each previous) step store the value of optimal fitness 
itself in array best and the location of the last change-point of the 
optimal partition in array last. 

It remains to show how to obtain y op *(i?+l). For some r consider 
the set of all partitions (of these first R + l cells) whose last block 
starts with cell r (and by definition ends at -R+l). Denote the fitness 
of this last block by F(r). By the subpartition result in Appendix 
B the only member of this set that could possibly be optimal is 
that consisting of l J >opt (r — 1) followed by this last block. By the 
additivity in Eq. flTJ) the fitness of said partition is the sum of F(r) 



3 Bellman's explanation (before the word "programming" took on its current computational 
connotation) of how he chose this name is interesting. The Secretary of Defense at the time 
"... had a pathological fear and hatred of the word, research. ... You can imagine how he 
felt, then, about the term, mathematical. ... I felt I had to do something to shield ... the 
Air Force from the fact that I was really doing mathematics inside the RAND Corporation. 
... I was interested in planning ... But planning is not a good word for various reasons. I 
decided therefore to use the word, programming. I wanted to get across the idea that this was 
dynamic ... it's impossible to use the word, dynamic, in a pejorative sense. Try thinking of 
some combination that will possibly give it a pejorative meaning. It's impossible. Thus, I 
thought dynamic programming was a good name. It was something not even a Congressman 
could object to. 
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and the fitness of < J >opt (r — 1) saved from a previous step: 





A(l) is the special case where the last block comprises the entire 
data array and thus no previous fitness value is needed. Over the 
indicated range of r this equation expresses the fitness of all par- 
titions CP(R+1) that can possibly be optimal. Hence the value of 
r yielding the optimal partition ( J ) ° pt (R + 1) is the easily computed 
value maximizing A(r): 



At the end of this computation, when R — N, it only remains to 
find the locations of the change-points of the optimal partition. The 
needed information is contained in the array last in which we have 
stored the index r opt at each step. Using the corollary in Appendix B 
it is a simple matter to use the last value in this array to determine 
the last change-point in P opt (N), peel off the end section of last 
corresponding to this last block, and repeat. That is to say, the set 
of values 

cpi = last(N); cp2 = last(cpi — l); cp^ = last(cp2 — l)] ■ ■ ■ (10) 

are the index values giving the locations of the change-points, in 
reverse order. Note that the positions of the change-points are not 
necessarily fixed until the very last iteration, although in practice 
it turns out that they become more or less "frozen" once a few 
succeeding change-points have been detected. MatLat0 code for 
optimal partitioning of event data is given in Appendix A. 

2.7 Fixing the Parameter in the Prior Distribution for 



As mentioned in §1.91 the output of the algorithm is dependent on 
value of the parameter 7, characterizing the assumed prior distri- 
bution for the number of blocks, eq. ([3]). In many applications the 
results are rather insensitive to the value as long as the signal-to- 
noise ratio is even moderately large. Nevertheless extreme values 

4 ™The Mathworks, Inc 
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.opt 



argmax[A(r)] . 



(9) 



Nblock. 
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of this parameter give bad results in the form of clearly too few 
or too many blocks. In any case one must select a value to use in 
applications. 

This situation is much like that of selecting a smoothing param- 
eter in various data analysis applications, e.g. density estimation. 
In such contexts there is no perfect choice but instead a tradeoff be- 
tween bias and variance. Here the tradeoff is between a conservative 
choice not fooled by noise fluctuations but potentially missing real 
changes, and a liberal choice better capturing changes but yield- 
ing some false detections. Several approaches have proven useful in 
elucidating this tradeoff. Merely running the algorithm with a few 
different values can indicate a range over which the block represen- 
tation is reasonable and not very sensitive to the parameter value 
(cf. Fig. OP). 

The discussion of fitness functions below in Ogives implementa- 
tion details of an objective method for calibrating ncp_prior as a 
function of the number of data points. It is based on relating this 
parameter to the false positive probability - that is, the relative 
frequency with which the algorithm falsely reports detection of a 
change-point in data with no signal present. It is convenient to use 
the complementary quantity 

Po = 1 — false positive probability . (11) 

This number is the frequency with which the algorithm correctly 
rejects the presence of a change-point in pure noise. Therefore it 
is also the probability that a change-point reported by the algo- 
rithm with this value of ncp_prior is indeed statistically significant 
- hence we call it the correct detection rate for single change-points. 

The needed ncp_prior-po relationship is easily found by noting 
that the rates of correct and incorrect responses to fluctuations in 
simulated pure noise can be controlled by adjusting the value of 
ncp_prior. The procedure is: generate a synthetic pure-noise time 
series; apply the algorithm for a range of ncp_prior; select the 
smallest value that yields false detection frequency equal or less than 
the desired rate, such as .05. The values of ncp_prior determined 
in this way are averaged over a large number of realizations of the 
random data. The result depends on only the number of data points 
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and the adopted value of po: 



ncpjprior = ip(N,po) . 



(12) 



Results from simulations of this kind are given below for the various 
fitness functions in § §3.1[ 13.21 and 13.31 We have no exact formulas, 
but rather fits to these numerical simulations. 

The above discussion is useful in the simple problem of decid- 
ing whether or not a signal is present above a background of noisy 
observations. In other words we have a procedure for assigning a 
value of ncp_prior that results in an acceptable frequency of spu- 
rious change-points, or false positives, when searching for a single 
statistically significant change. Real-time triggering on transients 
( §4.31) is an example of this situation, as is any case where detection 
of a single change-point is the only issue in play. 

But elucidating the shape of an actual detected signal lies outside 
the scope of the above procedure, since it is based on a pure noise 
model. A more general goal is to limit the number of both false 
negatives and false positives in the context of an extended signal. 
The choice of the parameter value here depends on the nature of 
the signal present and the signal-to-noise level. One expects that 
somewhat larger values of ncp_prior are necessary to guard against 
corruption of the estimate of the signal's shape due to errors at 
multiple change-points. 

This idea suggests a simple extension of the above procedure. 
Assume that a value of po, the probability of correct detection of 
an individual change-point, has been adopted and the correspond- 
ing value of ncp_prior determined with pure noise simulations as 
outlined above and expressed in eq. ( TT2|) . For a complex signal our 
goal is correct detection of not just one, but several change-points, 
say N cp in number. The trick is to treat each of them as an inde- 
pendent detection of a single change-point with success rate po- The 
probability of all N cp successes follows from the law of compound 
probabilities: 



There are problems with this analysis in that the following are not 
true: 

(1) Change-point detection in pure noise and in a signal are the 




(13) 



same. 
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(2) The detections are independent of each other. 

(3) We know the value of N cp . 

All of these statements would have to be true for eq. f[T3"l) to be 
rigorously valid. We propose to regard the first two as approximately 
true and address the third as follows: Decide that the probability of 
correctly detecting all the change-points should be at least a high as 
some value p*, such as 0.95. Apply the algorithm using the value of 
ncp_prior = ip(N,p*) given by the pure noise simulation. Use eq. 
(1T31) and the number of change-points thus found to yield a revised 
value 

ncpjprior = tp(N,pl^ Ncp ) . (14) 

Stopping when the iteration produces no further modification of the 
set of change-points, one has the recommended value of ncp_prior. 
This ad hoc procedure is not rigorous, but it establishes a kind of 
consistency and has proven useful in all the cases where we have tried 
it, e.g. Norris Gehrels and Scargle 2010 Norris Gehrels and Scargle 2011 




8 10 

ncp_prior 



Figure 1: Cross-validation error of BATSE TTE data (averaged over 532 GRBs, 
8 random subsamples, and time) for a range of values of -log 7 = with 3tr error 
bars. 

Fig. [1] shows another approach, based on cross-validation of the 
data being analyzed (c/. |Hogg 2008] ) . This study uses the collec- 
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tion of raw TTE data at the BATSE web site 

f tp : / /legacy . gsf c . nasa . gov/ compton/dat a/bat se/ ascii_dat a/bat se_tte/. 

The files for each of 532 GRBs contain time tags for all photons de- 
tected for that burst. The energy and detector tags in the data files 
were not used here, but §4.11 shows an example using the former. 
An ordinary 256-bin histogram of all photon times for each of 532 
GRBs was taken as the true signal for that burst. Eight random sub- 
samples smaller by a factor of 8 were analyzed with the algorithm 
using the fitness in eq. ffl9|) . The average RMS error between these 
block representations (evaluated at the same 256 time points) and 
the histogram is roughly flat over a broad range. While this illustra- 
tion with a relatively homogeneous data set should obviously not be 
taken as universal, the general behavior seen here - determination 
of a broad range of nearly equally optimal values of ncp_prior - is 
characteristic of a wide variety of situations. 

2.8 Analysis of Variance 

Assessment of uncertainty is an important part of any data analysis 
procedure. The observational errors discussed throughout this paper 
are propagated by the algorithm to yield corresponding uncertainties 
in the block representation and its parameters. The propagation of 
stochastic variability in the astronomical source is a separate issue, 
called cosmic variance, and is not discussed here. 

Since the results here comprise a complete function defined by 
a variable number of parameters, quantification of uncertainty is 
considerably more intricate than for a single parameter. In partic- 
ular one must specify precisely which of the block representation's 
aspects is at issue. Here we discuss three: (a) the full block rep- 
resentation, (b) the very presence of the change-points themselves, 
and (c) locations of change-points. 

A straightforward way to deal with (a) is by bootstrap analysis. 
As described in |Efron and Tibshirani 1 998] for time series data this 
procedure is rather complicated in general. However resampling of 
event data in the manner appropriate to the bootstrap is trivial. The 
procedure is to run the algorithm on each of many bootstrap sam- 
ples and evaluate the resulting block representations at a common 
set of evenly spaced times. In this way models with different num- 
bers and locations of change-points can be added, yielding means 
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and variances for the estimated block light curves. The bootstrap 
variance is an indicator of light curve uncertainty. In addition com- 
parison of the bootstrap mean with the block representation from 
the actual data adds information about modeling bias. The former 
is rather like a model average in the Bayesian context. This average 
typically smoothes out the discontinuous block edges present in any 
one representation. In some applications the bootstrap mean may 
be more useful than the block representation. 

This method does not seem to be useful for studying uncertainty 
in the change-points themselves, in particular their number, presum- 
ably because the duplication of data points due to the replacement 
feature of the resampling yields excess blocks (but with random lo- 
cations and small amplitude variance, and therefore with little effect 
on the mean light curve). 

By (b) is meant an assessment of the statistical significance of the 
identification of a given change point. For a given change-point we 
suggest quantification of this uncertainty by evaluating the ratio of 
the fitness functions for the two blocks on either side of that change- 
point to that of the single block that would exist if the change-point 
were not there. The corresponding difference of the (logarithmic) 
fitness values should be adjusted by the value of the constant param- 
eter ncp_prior, for consistency with the way fitness is computed in 
the algorithm. 

Finally, (c) is easily addressed in an approximate way by fixing all 
but one change-point and computing fitness as a function of the loca- 
tion of that change-point. This assessment is approximate because 
by fixing the other change-points because it ignores inter-change- 
point dependences. One then converts the run of the fitness func- 
tion with change-point location into a normalized probability dis- 
tribution, giving comprehensive statistical information about that 
location (mean, variance, confidence interval, etc.) 

Sample results of all of these uncertainty measures in connection 
with analysis of a gamma-ray burst light curve are shown below in 
P~T| especially Fig. EJ 

2.9 Multivariate Time Series 

Our algorithm's intentionally flexible data interface not only allows 
processing a wide variety of data modes but also facilitates joint 
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analysis of mode combinations. This feature allows one to obtain 
the optimal block representation of several concurrent data streams 
with arbitrary modes and sample times. This analysis is joint in 
the sense that the change-points are constrained to be at the same 
times for all the input series; in other words the block edges for all 
of the input data series line up. The representation is optimal for 
the data as a whole but not for the individual time series. 

To interpret the result of a multivariate analysis one can study 
the blocks in the different series in two ways: (a) separately, but with 
the realization that the locations of their edges are determined by 
all the data; or (b) in a combined representation. The latter requires 
that there be a meaningful way to combine amplitudes. For example 
the plot of a joint analysis of event and binned data could simply 
display the combined event rate for each block, perhaps adjusting 
for exposure differences. For other modes, such as photon events 
and radio frequency fluxes, a joint display would have to involve a 
spectral model or some sort of relative normalization. The example 
in §4.21 below will help clarify these issues. 

The idea extending the basic algorithm to incorporate multiple 
time series is simple. Each datum in any mode has a time-tag asso- 
ciated with it - for example the event time, the time of a bin center, 
or the time of a point measurement. The joint change-points are 
allowed to occur at any one of these times. Hence the times from 
all of the separate data streams are collected together into a single 
ordered array; the ordering means that the times - as well as the 
measurement data - from the different modes are interleaved. The 
cartoon in Fig. [2] shows how the individual concatenated times and 
data series are placed in separate blocks in a matrix (top) and then 
redistributed (bottom) by ordering the combined times. Then the 
fitness function for a given data series can be obtained from the 
corresponding data slice (e.g. the horizontal dashed line in the fig- 
ure, for Series #2). The zero entries in these slices (indicated by 
white space in the figure) are such that the fitness function for data 
from each series is evaluated for only the appropriate data and mode 
combination. The overall fitness is then simply the sum of those for 
the several data series. The details of this procedure are described 
in the code provided in Appendix A ( £fA"|) . 
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Ordered Times 



Figure 2: Cartoon depicting an example of how three data series are first con- 
catenated into a matrix (top) and then redistributed by ordering the combined 
time-tags (bottom). The cost functions for the series can then be computed 
from the data in horizontal slices {e.g. dashed line) and combined, allowing the 
change-points to be at any of the time tags. 

2.10 Comparison with Theoretical Optimal Detection Ef- 
ficiency 

How good is the algorithm at extracting weak signals in noisy data? 
This section gives evidence that it achieves detection sensitivity 

closely approaching ideal theoretical limits. The formalism in |Arias- Castro, Donoho and Huo 
treats detection of geometric objects in data spaces of arbitrary di- 
mension using multiscale methods. The one dimensional special 
case in §11 of this reference is essentially equivalent to our problem 
of detecting a single block in noisy time series. 

Given N measurements normalized so that the observational er- 
rors ~ N(0, a) (normally distributed with zero mean and variance 
a 2 ), these authors show that the threshold for detection is 

A x = a yfe logN . (15) 

This result is asymptotic {i.e. valid in the limit of large N). It is 
valid for a frequentist detection strategy based on testing whether 
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the maximum of the inner product of the model with the data ex- 
ceeds the quantity in eq. (|T5|) or not. These authors state "In 
short, we can efficiently and reliably detect intervals of amplitude 
roughly yj 2 logiV , but not smaller." More formally the result is 
that asymptotically their test is powerful for signals of amplitude 
greater than A\ and powerless for weaker signals. 
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Figure 3: One hundred unit variance normally distributed measurements - zero- 
mean (+) except for a block of events 25-75 (dots). In the four panels the block 
amplitudes are 0.2, .32, .5, and 1.0 in units of the Arias-Castro el al. threshold 
\J 2 logN. Thick lines show the blocks, where detected, with thin vertical lines 
at the change-points. 

It is of interest to see how well our algorithm stacks up against 
these theoretical results, since the two analysis approaches (matched 
filter test statistic vs. Bayesian model selection) are fundamentally 
different. Consider a simulation consisting of normally distributed 
measurements at arbitrary times in an interval. These variates are 
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taken to be zero-mean-normal, except over an unknown sub-interval 
where the mean is a fixed constant. In this experiment the events 
are evenly spaced, but only their order matters, so the results would 
be the same for arbitrary spacing of the events. Fig. [3] shows syn- 
thetic data for four simulated realizations with different values for 
this constant. The solid line is the Bayesian blocks representation, 
using the posterior in Eq. ( 11021) . For the small amplitudes in the 
first two panels no change-points are found; these weak signals are 
completely missed. In the other two panels the signals are detected 
and approximately correctly represented - with small errors in the 
locations of the change-points. 




Figure 4: Error in finding a single block vs. simulated block amplitude in units 
of Arias-Castro et al.'s threshold amplitude. The curves (from right to left) are 
for N = 32, 64, 128, 256, 1024 and 2048. 
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Fig. H] reports some results of detection of the same step-function 
process shown in Fig. [3j averaged over many different realizations 
of the observational error process and for several different values of 
N. The lines are plots of a simple error metric (combing the errors 
in the number of change-points and their locations) as a function of 
the amplitude of the test signal. The left panel is for the case where 
the number of points in the putative block is held fixed, whereas 
the right panel is this number is taken to be proportional to N, 
sometimes a more realistic situation. We have adopted the following 
definition for the threshold in this case: 



A = 8.^. (16) 

This formula is consistent with adjusting the normalized width in 
|Arias-Castro, Donoho and Huo 2003J with a factor N; 8 is an arbi- 
trary factor for plotting. 

Our method yields small errors when the signal amplitude is 
on the order or even somewhat smaller than the limit stated by 
|Arias-Castro, Donoho and Huo 2003 , showing that we are indeed 



close to their theoretical limit. The main difference here is that our 
results are for specific values of N and the theoretical results are 
asymptotic in N. 



3 Block Fitness Functions 



To complete the algorithm all that remains is to define the model 
fitness function appropriate to a particular data mode. By equation 
(j7|) it is sufficient to define a block fitness function, which can be 
any convenient measure of how well a constant signal represents the 
data in the block. Naturally this measure will depend on all data in 
the block and not on any outside it. As explained in §2.41 it cannot 
depend on any model parameters other than those specifying the 
locations of the block edges. In practice this means that block height 
(signal amplitude) must somehow be eliminated as a parameter. 
This can be accomplished, for example, by taking block fitness to 
be the relevant likelihood either maximized or marginalized with 
respect to this parameter. Either choice yields a quantity good 
for comparing alternative models, but not necessarily for assessing 
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goodness-of-fit of a single model. Note that these measures as such 
do not satisfy the additivity condition Eq. (jTJ). As long as the cell 
measurement errors are independent of each other the likelihood of 
a string of blocks is the product of the individual values, but not the 
required sum. But simply taking the logarithm yields the necessary 
additivity. 

There is considerable freedom in choosing fitness functions to 
be used for a given type of data. The examples described here have 
proven useful in various circumstances, but the reader is encouraged 
to explore other block-additive functions that might be more appro- 
priate in a given application. For all cases considered in this paper 
the fitness function depends on data in the block through summary 
parameters called sufficient statistics, capturing the statistical be- 
havior of the data. If these parameters are sums of quantities defined 
on the cells the computations are simplified; however this condition 
is not essential. 

Two types of factors in the block fitness can be ignored. A con- 
stant factor C appearing in the likelihood for each data cell yields 
an overall constant term in the derived logarithmic fitness function 
for the whole time series, namely iV log C. Such a term is indepen- 
dent of all model parameters and therefore irrelevant for the model 
comparison in the optimization algorithm. In addition, while a term 
in the block fitness that has the same value for each block does affect 
total model fitness, it contributes a term proportional to the number 
of blocks, and which therefore can be absorbed into the parameter 
derived from the prior on the number of blocks (cf. §1.91) . 

Many of the data modes discussed in the following subsections 
were operative in the Burst and Transient Source Experiment (BATSE) 
experiment on the NASA Compton Gamma Ray Observatory (GRO), 
the Swift Gamma-Ray Burst Mission, the Fermi Gamma Ray Space 
Telescope, and many x-ray and other high-energy observatories. 
They are also relevant in a wide range of other applications. 

In the rest of this section we exhibit expressions that serve as 
practical and reliable fitness functions for the three most common 
data modes: event data, binned data, and point measurements with 
normal errors. Some refinements of this discussion and some other 
less common data modes are discussed in Appendix C, $C] 
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3.1 Event Data 



For series of times of discrete events it is natural to associate one 
data cell ( §2.2p with each event. The following derivation of the 
appropriate block fitness will elucidate exactly what information 
the cells must contain to allow evaluation of the fitness for the full 
multi-block model. 

In practice the event times are integer multiples of some small 
unit ( §C.ip but it is often convenient to treat them as real numbers 
on a continuum. For example the fitness function is easily obtained 
starting with the unbinned likelihood known as the Cash statis- 
tic ( |Cash 1979] ; a thorough discussion is in |Tompkins 1999] ) . If 
M(t, 6) is a model of the time dependence of a signal the unbinned 
log-likelihood is 

\ogL{0) = £ logM(t n , 9) - f M(t, 6)dt , (17) 

where the sum is over the events and 9 represents the model pa- 
rameters. The integral is over the observation interval and is the 
expected number of events under the model. Our block model is 
constant with a single parameter, M(t, A) = A, so for block k 

logL {k) {\) = N {k Hog\ - AT (fc) , (18) 

where is the number of events in block k and is the length 
of the block. The maximum of this likelihood is at A = NW/T<> k \ 
yielding 



log L<$ ax + N<® = iV«( logiV( fc ) - logT«) . (19) 



The term is taken to the left side because its sum over the 
blocks is a constant (N, the total number of events) that is model- 
independent and therefore irrelevant. Moreover note that changing 
the units of time, say by a scale factor a, changes the log-likelihood 
by —N^ \og(a), irrelevant for the same reason. This felicitous 
property holds for other maximum likelihood fitness functions and 
removes what would otherwise be a parameter of the optimization. 
This effective scale invariance and the simplicity of eq. (fl9l) make its 
block sum the fitness function of choice to find the optimum block 
representation of event data. A possible exception is the case where 



31 



detection of more than one event at a given time is not possible, 
e.g. due to detector, deadtime, in which case the fitness function in 
Appendix C, §C.2I may be more appropriate. 

It is now obvious what information a cell must contain to allow 
evaluation of the sufficient statistics and by summing two 
quantities over the cells in a block. First it must contain the number 
of events in the cell. (This is typically one, but can be more depend- 
ing on how duplicate time tags are handled; see the code section in 
Appendix A, £JA] dealing with duplicate time-tags, or ones that are 
so close that it makes sense to treat them as identical). Second, it 
must contain the interval 

At n = (t n+ i - £ n _i)/2 , (20) 

representing the contribution of cell n to the length of the block. 
This interval contains all times closer to event n than to any other. 
It is defined by the midpoints between successive events, and gener- 
alizes to data spaces of any dimension, where it is called the Voronoi 
tessellation of the data points, |Okabe, Boots, Sugihara and Chiu 2000 



Scargle 2001a[ |Scargle 2001c| ). Because 1/At n can be regarded as 



an estimate of the local event rate at time t n , it is natural to visu- 
alize the corresponding data cell as the unit-area rectangle of width 
At n and height 1/At n . These ideas lead to the comment in §1.8l that 
the event-by-event adjustment for exposure can be implemented by 
shrinking At n by the exposure factor e n . 

It is interesting to note that the actual locations of the (indepen- 
dent) events within their block do not matter. The fitness function 
depends on only the number of events in the block, not their loca- 
tions or the intervals between them. This result flows directly from 
the nature of the underlying independently distributed, or Poisson, 
process (see Appendix B, 0B|) . 

We conclude this section with evaluation of the calibration of 
ncp_prior from simulations of signal-free observational noise as de- 
scribed in §2.71 The results of extensive simulations for a range of 
values of iV and the adopted false positive rate p introduced in Eq. 
(fTTl) were found to be well fit with the formula 



ncp_prior = 4 - 73.53p iV~- 478 ( 21) 

For example, with po = .01 and N = 1,000 this formula gives 
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ncp_prior = 3.97. 



3.2 Binned Event Data 

The expected count in a bin is the product XeW of the true event 
rate A at the detector, a dimensionless exposure factor e ( §1.8[) . and 
the width of the bin W. Therefore the likelihood for bin n is given 
by the Poisson distribution 

(Xe n W n ) N -e- Xe " w - 
n ~ AM ' {22} 

where N n is the number of events in bin n, A is the actual event 
rate in counts per unit time, e n is the exposure averaged over the 
bin, and W n is the bin width in time units. Defining bin efficiency 
as w n = e n W n , the likelihood for block k is the product of the 
likelihoods of all its bins: 

M( fe ) 

L«= J] L n = X N(k) e- Xw(k) . (23) 

71=1 

Here is the number of bins in block k, 



w 



E W n (24) 



n=l 

is the sum of the bin efficiencies in the block, and 

M {k) 

N {k) =J2 N n (25) 

n=l 

is the total event count in the block. The factor (e n W n ) Nn /N n \ has 
been discarded because its product over all the bins in all the blocks 
is a constant (depending on the data only) and therefore irrelevant 
to model fitness. The log-likelihood is 

logL (fc) = iV (fc) logA - \w {k) , (26) 

identical to eq. ffTSj) with iyW playing the role of T^ k \ a natural 
association since it is an effective block duration. Moreover in ret- 
rospect it is understandable that unbinned and binned event data 
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have the same fitness function, especially in view of the analysis in 
§C.1I where ticks are allowed to contain more than one event and 
are thus equivalent to bins. In addition the way variable exposure 
is treated here could just as well have been applied to event data 
in the previous section. Note that in all of the above the bins are 
not assumed to be equal or contiguous - there can be arbitrary gaps 
between them ( §1.71) . 




log number of bins 



Figure 5: Simulation study, based on the false positive rate of 0.05, to determine 
ncp_prior = -log(7) for binned data. Contours of this parameter are shown as a 
function of the number of bins and number of data points (logarithmic x- and 
y- axes, respectively). The heavy dashed line indicates the undesirable region 
where the numbers of bins and data points are equal. 

We now turn to the determination of ncp_prior for binned data. 
Figure [5] is a contour plot of the values of this parameter based on 
a simulation study with bins containing independently distributed 
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events. These contours are very insensitive to the false positive rate, 
which was taken as .05 in this figure. 



3.3 Point Measurements 

A common experimental scenario is to measure a signal s(t) at a se- 
quence of times t n ,n = 1,2, ... ,N in order to characterize its time 
dependence. Inevitable corruption due to observational errors is fre- 
quently countered by smoothing the data and/or fitting a model. As 
with the other data modes Bayesian Blocks is a different approach 
to this issue, making use of knowledge of the observational error dis- 
tribution and avoiding the information loss entailed by smoothing. 
In our treatment the set of observation times t n , collectively known 
as the sampling, can be anything - evenly spaced points or other- 
wise. Furthermore we explicitly assume that the measurements at 
these times are independent of each other, which is to say the errors 
of observation are statistically independent. 

Typically these errors are random and additive, so that the ob- 
served time series can be modeled as 

x n = x(t n ) = s(t n ) + z n n = 1, 2, . . . N . (27) 

The observational error z n , at time t n , is known only through its 
statistical distribution. Consider the case where the errors are taken 
to obey a normal probability distribution with zero mean and given 
variance: 

P(z n )dz n = = e-^ )2 dz n . (28) 

0-„V27r 

Using eqs. ( 127)) and (J2SJ) if the model signal is the constant s = X 
the likelihood of measurement n is 

1 1 i x„-\ \2 . . 

e"2 ( ^^ ) . (29) 



(7 n V27r 



Since we assume independence of the measurements the block k 
likelihood is 

L« = II L n = e-* ^ (£ ^ )2 . (30) 

n Ilm 

Both the products and sum are over those values of the index such 
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that t lies in block k. The quantities multiplying the exponentials 
in both the above equations are irrelevant because they contribute 
an overall constant factor to the total likelihood. 

We now derive the maximum likelihood fitness function for this 
data mode (with other forms based on different priors relegated to 
Appendix C, §gC31 EH and EZD • The quantities 

a k = \n^ ( 31 ) 

6* = "E^ (32) 

1 X 2 

Ck =2^ (33) 

appear in all versions of these fitness functions; the first two are 
sufficient statistics. 

As usual we need to remove the dependence of eq. fl30l) on the 
parameter A, and here we accomplish this result by finding the value 
of A which maximizes the block likelihood, that is by maximizing 



1 x^ )2 ^ (34) 



This is easily found to be 



Amax — ^ —T, I ^ —p (35) 

= -b k /2a k (36) 

As expected this maximum likelihood amplitude is just the weighted 
mean value of the observations x n within the block, because defining 
the weights 

j_ 

w n = a f i , (37) 

yields 

A m ax = W n X n ■ (38) 
n 

Inserting Eq. (13"6"|) into the log of Eq. ( 13T)|) with the irrelevant 
factors omitted yields the corresponding maximum value of the log- 
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likelihood itself: 



^L^-W^-^f (39) 

z n a n 

where again the sums are over the data in block k. Expanding the 
square 

iog£SL=-i[ eI+^e^+Ai:4 i, (40) 
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dropping the first term (quadratic in x) which also sums to a model- 
independent constant, and using equations (13Tj) and (I3"2"j) we arrive 
at 



logL^L = &|/4a fe . (41) 



As expected each data cell must contain x n and a n but we now 
see that these quantities enter the fitness function through the sum- 
mands in the equations flBTj) and (1521) defining a fc and 6 fc (c^ does not 
matter), namely l/(2a^) and —x n /a^. The way the corresponding 
block summations are implemented is described in Appendix A £jA], 
(c.f. data mode #3). 

A few additional notes may be helpful. In the familiar case in 
which the error variance is assumed to be time-independent a can be 
carried as an overall constant and a n does not have to be specified 
in each data cell. The t n are only relevant in determining which cells 
belong in a block and do not enter the fitness computation explicitly. 
And the fitness function in Eq. (j41j) is manifestly invariant to a scale 
change in the measured quantity, as is the alternative form derived 
in Appendix C, Eq. (194"|) . That is to say under the transformation 

x n ax n , a n aa n , (42) 

corresponding for example to a simple change in the units of x and 
a, the fitness does not change. 

Figure El exhibits a simulation study to calibrate ncp_prior for 
normally distributed point measurements. For illustration the pure 
noise data simulated was normally distributed with a mean of 10 and 
unit variance. The left-hand panel shows how the false positive rate 
is diminished as ncp_prior is increased, for the 8 values of N listed 
in the caption. The horizontal line is at the adopted false positive 
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rate of 0.05; the points at which these curves cross below this line 
generate the curve shown in the bottom panel. The linear fit in the 
latter depicts the relation ncp_prior = 1.32 + 0.577 log 10 (7V). This 
relation is insensitive to the signal-to-noise ratio in the simulations. 
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Figure 6: Simulations of point measurements (Gaussian noise with signal-to- 
noise ratio of 10) to determine ncp_prigg = -log(7). Top: false positive fraction 
Po vs. value of ncp_prior with separate curves for the values N = 8, 16, 32, 64, 
128, 256, 512 and 1024 (left to right; alternating dots, + and circles). The points 
at which the rate becomes unacceptable (here .05; dashed line) determines the 
recommended values of ncp_prior shown as a function of N in the bottom panel. 



4 Examples 



The following subsections present illustrative examples with sample 
data sets, demonstrating block representation for TTE data, mul- 
tivariate time series, triggering, the empty block problem for TTE 
data, and data on the circle. 

4.1 BATSE Gamma Ray Burst TTE Data 

Trigger 551 in the BATSE catalog (4B catalog name 910718) was 
chosen to exemplify analysis of time-tagged event data as it has 
moderate pulse structure. See §2.71 for a description of the data 
source. Figure [7] shows analysis of all of the event data in the top 
panels, and separated into the four energy channels in the lower 
panels. On the left are optimal block representations and the right 
shows the corresponding data in 32 evenly spaced bins. 

In all five cases the optimal block representations based on the 
block fitness function for event data in eq. f|T9|) are depicted for 
two cases, using values the values of ncp_prior: (1) from eq. ( 121]) 
with po = 0.05 (solid lines); and (2) found with the iterative scheme 
described in §2.71 (lightly shaded blocks bounded by dashed lines). 
These two results are identical for all cases except channel 3, where 
the iterative scheme's more conservative control of false positives 
yields fewer blocks (9 instead of 13). 

Note that the ordinary histograms of the photon times in the 
right-hand panels leave considerable uncertainty as to what the sig- 
nificant and true structures are. In the optimal block representations 
two salient conclusions are clear: (1) there are three pulses, and (2) 
they are most clearly delineated at higher energies. 
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Figure 7: BATSE TTE data for Trigger 0551. Top panels: all photons. 
Other panels: photons in the four BATSE energy channels. Left column 
shows Bayesian Block representations: default ncp_prior = solid lines; iterated 
ncp_prior = shaded/dashed lines. Right column: ordinary evenly spaced binned 
histograms. 



This figure depicts the error analysis procedures described above 
in §2B 
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Figure 8: Error analysis for the data in Channel 4 from Fig. zooming in on 
the time interval with most of the activity. Top: Heavy solid line is bootstrap 
mean (256 realizations), with thin lines giving the ±lcr RMS deviations, all 
superimposed on the BB representation. Bottom: approximate posterior distri- 
bution functions for the locations of the change-points, obtained by fixing all of 
the others. 
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4.2 Multivariate Time Series 

This example in Fig. [9] demonstrates the multvariate capability 
of Bayesian Blocks by analyzing data consisting of three different 
modes sampled randomly from a synthetic signal. Time-tagged 
events, binned data, and normally distributed measurements were 
independently drawn from the same signal and analyzed separately, 
yielding the block representations depicted with thin lines. 

The joint analysis of the data combined using the multivariate 
feature described above in §2.91 is represented as the thick dashed 
line. None of these analyses is perfect, of course, due to the sta- 
tistical fluctuations in the data. The combined analysis finds a few 
spurious change-points, but overall these do not represent serious 
distortions of the true signal. The individual analyses are some- 
what poorer at capturing the true change-points and only the true 
change-points. Hence in this example the combined analysis makes 
effective use of disparate data modes from the same signal. 

4.3 Real Time Analysis: Triggers 

Because of its incremental structure our algorithm is well suited for 
real-time analysis. Starting with a small amount of data the algo- 
rithm typically finds no change-points at first. Then by determining 
the optimal partition up to and including the most recently added 
data cell the algorithm effectively tests for the presence of the first 
change-point. The real time mode can be selected simply by trig- 
gering on the condition last(K) > 1 inserted into the code shown 
in Appendix A , £jAj just before the end of the basic iterative loop 
on R. For the entry of 1 in each element of array last means that 
the optimal partition consists of the whole array encountered so far. 
It is thus obvious that this first indication of change-point cannot 
yield more than one change-point. 

Thus the algorithm can be set to return at the first significant 
change-point. Other more complicated halting or return conditions 
can be programmed into the algorithm, such as returning after a 
specified number of change-points have been found, or when the 
location of a change-point has not moved for a specified length of 
time, etc. Essentially any condition on the change-points or the 
corresponding blocks can be imposed as a halt-and-return condition. 

The real time mode is mainly of use to detect the first sign of 
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a time- dependent signal rising significantly above a slowly varying 
background. For example, in a photon stream the resulting trigger 
may indicate the presence of a new bursting or transient source. 

The conventional way to approach problems of this sort is to re- 
port a detection if and when the actual event rate, averaged over 
some interval, exceeds one or more pre- set thresholds. See [Band 2002] 
for an extensive discussion, as well as |Fenimore et al. 20014IMcLean et al. 2 003 , 
ISchmidt 1999] for other applications in high energy astrophysics. 
One must consider a wide range of configurations: "BAT uses about 
800 different criteria to detect GRBs, each defined by a large num- 
ber of commandable parameters." [McLean et al. 2003] . Both the 
size and locations of the intervals over which the signal is averaged 
affect the result, and therefore one must consider many different 
values of the corresponding parameters. The idea is to minimize 
the chances of missing a signal because, for example, its duration 
is poorly matched to the interval size chosen. If the background is 
determined dynamically, by averaging over an interval in which it 
is presumed there is no signal, similar considerations apply to this 
interval. 

Our segmentation algorithm greatly simplifies the above consid- 
erations, since predefined bin sizes and locations are not needed, 
and the background is automatically determined in real time. In 
practice there can be a slight complication for a continuously ac- 
cumulating data stream, since the N 2 dependence of the compute 
time may eventually make the computations unfeasible. A simple 
countermeasure is to analyze the data in a sliding window of mod- 
erate size - large enough to capture the desired changes but not so 
large that the computations take too long. Slow variations in the 
background in many cases could mandate something like a sliding 
window anyway. 

Because of additional complexities, such as accounting for back- 
ground variability and the Pandora's box that spectral resolution 
opens [Band 2002] . we will defer a serious treatment of triggers to a 
future publication. 

We end with a few comments on the false alarm (also called false 
positive) rate in the context of triggers. The considerations are very 
similar to the tradeoff discussed in the context of the choice for 
the parameter ncp_prior described in §1.9[ §2.7[ and $3] for the 
various data modes. Even if no signal is present a sufficiently large 
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(and therefore rare) noise fluctuation can trigger any algorithm's 
detection criteria. Unavoidably all detection procedures embody a 
trade-off between sensitivity and rate of false alarms. Other things 
being equal, making an algorithm more able to trigger on weak 
signals renders it more sensitive to noise fluctuations. Conversely 
making an algorithm shun noise fluctuations renders it insensitive to 
weak signals. In practice one chooses a balance of these competing 
factors based on the relative importance of avoiding false positives 
and not missing weak signals. Hence there can be no universal 
prescription. 

4.4 Empty Blocks 

Recall that blocks are taken to begin and end with data cells ( §2.5)) . 
This convention means that no block can be empty: each much 
contain at least its initiating data cell. Hence in the case of event 
data, blocks cannot represent intervals of zero event rate. This con- 
straint is of no consequence for the other two data modes. There 
is nothing special about zero (or even negative) signals in the case 
of point measurements. Zero signal would be indicated by inter- 
vals containing only measured values not significantly different from 
zero. There is also no issue for binned data as nothing prevents 
a block from consisting of one or more empty data bins. In many 
event data applications zero signal may never occur (e.g. if there is 
a significant background over the entire observation interval). But 
in other cases it may be useful to represent such intervals in the 
form of a truly empty block, with corresponding zero height. 

Allowing such null blocks is easily implemented in a post-processing 
step applied to each of the change-points. The idea is to consider 
reassignment of data cells at the start or end of a block to the adjoin- 
ing block while leaving the block lengths unchanged. For a given 
change-point separating a pair of two blocks ("left" and "right") 
there are two possibilities: (a) the datum marking the change-point 
itself, currently initiating the right block, can be moved from the 
right to the left block; (b) the datum just prior to the change-point 
itself, currently ending the left block, can be moved from the left 
block to the right block. Straightforward evaluation of the relevant 
fitness functions establishes whether one of these moves increases 
the fitness of the pair, and if so which one. (It is impossible that 
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this calculation will favor both moves (a) and (b); taken together 
they yield no net change and therefore leave fitness unchanged.) 

The suggested procedure is to carry out this comparison for each 
change-point in turn and adjust the populations of the blocks ac- 
cordingly. We have not proved that this ad hoc prescription yields 
globally optimal models with the non-emptiness constraint removed, 
but it is obvious that the prescription can only increase overall model 
fitness. It is quite simple computationally and there is no real down- 
side to using it routinely, even if the moves are almost never trig- 
gered. A code fragment to implement this procedure is given in 
Appendix A, JA] 

4.5 Blocks on the Circle 

Each of the data spaces discussed so far has been a linear interval 
with a well defined beginning and end. A circle does not have this 
property. Our algorithm cannot be applied to data defined on a 
circlejl such as directional measurements, because it starts with the 
first data point and iteratively works its way forward along the in- 
terval to the last point. Hence the first and last points are treated 
as distant, not as the pair of adjacent points that they are. Any 
choice of starting point, such as the coordinate origin for angles 
on [0,27r], disallows the possibility of a block containing data just 
before and after it (on the circle). In short, the iterative (mathe- 
matical induction-like) structure of the algorithm prevents it from 
being independent of the arbitrary choice of origin, which on a circle 
is completely arbitrary. We have been unable to find a solution to 
this problem using a direct application of dynamical programming. 

However there is a method that provides exact solutions at the 
cost of about one order of magnitude more computation time. First 
unfold the data with an arbitrary choice for the fiducial origin. The 
resulting series starts at this origin, continues with the subsequent 
data points in order, and ends at the datum just prior to the fiducial 
origin. Think of cutting a loop of string and straightening it out. 

The basic algorithm is then applied to the data series obtained 
by concatenating three copies of the unfolded data. The underly- 
ing idea is that the central copy is insulated from any effects of 

5 Of course the case where the measured value is confined to a specific subinterval of the 
circle is not a problem. 
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the discontinuity introduced by the unfolding. In extensive tests on 
simulated data this algorithm performed well. One check is whether 
or not the two sets of change-points adjacent to the two divisions 
between the copies of the data are always equivalent (modulo the 
length of the circle). These results suggest but do not prove cor- 
rectness for all data; there may be pathological cases for which it 
fails. Of course this N 2 computation will take ~ 9 times as long as 
it would if the data were on a simple linear interval. 

Figure [10] shows simulated data representing measurements of an 
angle on the interval [0, 2tt]. In this case the procedure outlined 
above captures the central block (bottom panel) straddling the ori- 
gin that is broken into two parts if the data series is taken to start 
at zero (upper panel). Note that the two blocks just above and 
below 2n in the upper panel, are rendered as a single block in the 
central cycle in the bottom panel. Figure [JTJ shows the same data 
shown in Figure [TDI plotted explicitly on a circle. 
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Figure 9: Multivariate analysis of synthetic signal consisting of two blocks sur- 
rounding a Gaussian shape centered on the interval [0,1] (solid line). Optimal 
blocks for three independent data series drawn randomly from the probability 
distribution corresponding to this signal are thin lines: 1024 event times (dash); 
4096 events in 32 bins (dot-dash); and 32 random amplitudes normally dis- 
tributed with mean equal to the signal at random times uniformly distributed 
on [0,1] and constant variance (dots). The thicker dashed line is the combined 
analysis of all three. 
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Figure 10: Data on the circle: events drawn from two normal distributions, 
centered at it and 0, the latter with some points wrapping around to values below 
2n. Optimal blocks are depicted with thick horizontal bars superimposed on 
ordinary histograms. Top: block representation on the interval [0,27r]. Bottom: 
Block representation of three concatenated copies of the same data on [0,67r]. 
Vertical dotted lines at 2w and 4tt indicate boundaries between the copies. The 
blocks in the central copy, between these lines, are not influenced by end effects 
and are the correct optimal representation of these circular data. 
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Figure 11: Optimal block representation of the same data as in FigurelTOl (cf. the 
middle third of the bottom panel) plotted on the circle. The origin corresponds 
to the positive x-axis. and scale of the radius of the circle is arbitrary. 
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As a footnote, one application that might not be obvious is the 
case of gamma-ray burst light curves which are short enough that the 
background is accurately constant over the duration of the burst. If 
all of the data are rescaled to fit on a circle, then the pre- and post- 
burst background would automatically be subsumed into a single 
block (covering intervals at the beginning and end of the observation 
period). This procedure would be applicable to bursting light curves 
of any kind if and only if the background signal is constant, so that 
the event rates before and after the main burst are the same. 
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5 Conclusions and Future Work 



The Bayesian Blocks algorithm finds the optimal step function model 
of time series data by implementing the dynamical programming 
algorithm of [Jackson et al. 2005] . It is guaranteed to find the rep- 
resentation that maximizes any block-additive fitness function, in 
time of order iV 2 , and replaces the greedy approximate algorithm in 
|Scargle 1998| . Its real-time mode triggers on the first statistically 



significant rate change in a data stream. 

This paper addresses the following issues in the use of the algo- 
rithm for a variety of data modes: gaps and exposure variations, 
piecewise linear and piecewise exponential models, the prior distri- 
bution for the number of blocks, multivariate data, the empty block 
problem (for event data), data on the circle, dispersed data, and 
analysis of variance ("error analysis"). The algorithm is shown to 



closely approach the theoretical detection limit derived in Arias-Castro, Donoho and Huo 2003 

Work in progress includes extensions to generalized data spaces 
such as those of higher dimensions (cf. |Scargle 2001c| ), and speed- 
ing up the algorithm. 
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A Reproducible Research: MatLab Code 



This paper implements the spirit of Reproducible Research, a 
publication protocol initiated by John Claerbout |Claerbout 1990] 
and developed by others at Stanford and elsewhere. The underlying 
idea is that the most effective way of publishing research is to include 
everything necessary to reproduce all of the results presented in the 
paper. In addition to all relevant mathematical equations and the 
reasoning justifying them, full implementation of this protocol re- 
quires that the data files and computer programs used to prepare all 
figures and tables are included. Cogent arguments for Reproducible 
Research, an overview of its development history, and honest as- 
sessment of its successes and failures, are eloquently described in 
Donoho et al. (2008)| . 

Following this discipline all of the MatLab code and data files 
used in preparing this paper are available as auxiliary material. In- 
cluded is the file "read_me . txt" with details and a script "reproduce_f igures .m" 
that erases all of the figure files and regenerates them from scratch. 
In some cases the default parameters implement shorter simulation 
studies than those that were used for the figures in the paper, but 
one of the features of Reproducible Research is that such parameters 
and other aspects of the code can be changed and experimented at 
will. Accordingly this collection of scripts includes illustrative ex- 
emplars of the use of and algorithms and serves as a tutorial for the 
methods. 

In addition here is a commented version of the key fragment of 
the MatLab script (named f ind_blocks .m) for the basic algorithm 
described in this paper: 

°/ For data modes 1 and 2: 

% nn_vec is the array of cell populations. 

% Preliminary computation: 

block_length=tt_stop- [tt.start . 5* (tt (2 : end)+tt (1 : end-1) ) ' tt.stop] ; 

% 

°/ Start with first data cell; add one cell at each iteration 

% 

best = [] ; 
last = [] ; 

for R = l:num_points 
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°/ Compute fit_vec : fitness of putative last block (end at R) 
if data_mode == 3 °/ Measurements, normal errors 

sum_x_l = cumsum( cell_data( R:-l:l, 1 ) ) ' ; °/„sum(x/sig~2) 
sum_x_0 = cumsum( cell_data( R:-l:l, 2 ) ) ' ; °/„sum(l/sig~2) 
fit_vec=((sum_x_l(R:-l:l) ) ." 2 ) ./( 4*sum_x_0(R: -1 : 1) ) ; 

else 

arg_log = block_length(l :R) - block_length(R+l) ; 
arg_log( find( arg_log <= ) ) = Inf ; 
nn_cum_vec = cumsum( nn_vec(R: -1 : 1) ); 
nn_cum_vec = nn_cum_vec(R: -1 : 1) ; 

fit_vec = nn_cum_vec . * ( log( nn_cum_vec ) - log( arg_log ) ); 

end 

[ best(R), last(R)] = max( [ best ] + fit_vec - ncp_prior ); 

end 

% 

°/ Now find changepoints by iteratively peeling off the last block 
% 

index = last( num_points ); 
change .points = [] ; 
while index > 1 

change_points = [ index change_points ] ; 

index = last ( index - 1 ) ; 

end 

B Mathematical Details 

Partitions of arrays of data cells are crucial to the block model- 
ing which our algorithm implements. This appendix collects a few 
mathematical facts about partitions and the nature of independent 
events. 

B.l Definition of Partitions 

A partition of a set is a collection of its subsets that add up to the 
whole with no overlap. Formally, a partition is a set of elements, or 
blocks {B k } satisfying 

I = {jB k (43) 
k 
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and 

Bj p| B k = (the empty set) for j ^ k. (44) 

Note that these conditions apply to the partitions of the time series 
data by sets of data cells. The data cells themselves may or may not 
partition the whole observation interval, as either the completeness 
in eq. fT4S|) or the no-overlap condition in eq. (jUJ) may be violated. 

B.2 Reduction of Infinite Partition Space to a Finite One 

For a continuous independent variable, such as time, the space of 
all possible partitions is infinitely large. We address this difficulty 
by introducing a construct in which T and its partitions are repre- 
sented in terms of a collection of N discrete data cells in one-to-one 
correspondence with the measurements^ The blocks which make 
up the partitions are sets of data cells contiguous with respect to 
time-order of the cells. I.e. a given block consists of exactly all cells 
with observation times within some sub-interval of T. 

Now consider two sets of partitions of T: (a) all possible par- 
titions (b) all possible collections of cells into blocks. Set (a) is 
infinitely large since the block boundaries consist of arbitrary real 
numbers in T, but set (b) is a finite subset of (a). Nevertheless, 
under reasonable assumptions about the data mode, any partition 
in (a) can be obtained from some partition in (b) by deforming 
boundaries of its blocks without crossing a data point. Because the 
potential of a block to be an element of the optimum partition (see 
the discussion of block fitness in §3]) is a function of the content 
of the cells, such a transformation cannot substantially change the 
fitness of the partition. 

B.3 The Number of Possible Partitions 

How many different partitions of N cells are possible? Represent a 
partition by an ordered set of N zeros and ones, with one indicating 
that the corresponding time is a change-point, and zero that it is 
not. With two choices at each time, the number of combinations is 

^partitions = 2 ^ ■ ( 45 ) 

6 The cells may form a partition of T, as for example with event data with no gaps (see 
£13-11) . but it is not necessary that they do so. 
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Except for very short time series this number is too large for an 
exhaustive search, but our algorithm nevertheless finds the optimum 
over this space in a time that scales as only iV 2 . 

B.4 A Result for Subpartitions 

We here define subpartitions and prove an elementary corollary that 
is key to the algorithm. 



Definition: a subpartition of a given partition CP(/) 
is a subset of the blocks of CP(7). 



It is obvious that a subpartition is a partition of that subset of 
T consisting of those blocks. Although not a necessary condition 
for the result to be true, in all cases of interest here the blocks 
in the subpartition are contiguous, and thus form a partition of a 
subinterval of T. It follows that: 



Theorem: A subpartition CP' of an optimal partition CP(7) 
is an optimal partition of the subset I' that it covers. 



For if there were a partition of I', different from and fitter than CP', 
then combining it with the blocks of CP not in CP would, by the block 
additivity condition, yield a partition of Tfitter than CP, contrary to 
the optimality of CP. 

We will make use of the following corollary: 



Corollary: removing the last block of an optimal partition 
leaves an optimal partition. 
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B.5 Essential Nature of the "Poisson" Process 

The term Poisson process refers to events occurring randomly in 
time and independently of each other. That is, the times of the 
events, 

t n ,n = 1,2,..., N , (46) 

are independently drawn from a given probability distribution. Think 
of the events as darts thrown randomly at the interval. If the distri- 
bution is flat (i.e. the same all over the interval of interest) we have 
a constant rate Poisson process. In this special case a point is just 
as likely to occur anywhere in the interval as it is anywhere else; 
but this need not be so. What must be so in general - the essential 
nature of the Poisson process from a physical point of view - is the 
above-mentioned independence: each dart is not at all influenced by 
the others. Throwing darts that have feathers or magnets, although 
random, is not a Poisson process if these accoutrements cause the 
darts to repel or attract each other. 

This key property of independence determines all of the other 
features of the process. Most important are a set of remarkable 
properties of interval distributions (see e.g. |Papoulis 1965| ). The 
time interval between a given point t and the time t of the next 
event is exponentially distributed 

P( T )dr = \e- Xr dr , (47) 

where r = t — t^. The remarkable aspect is that it does not matter 
how to is chosen; in particular the distribution is the same whether 
or not an event occurs at to- This fact makes the implementation of 
event-by-event exposure straightforward ( §1.8j) . 

Note that we have not mentioned the Poisson distribution itself. 
The number of events in a fixed interval does obey the Poisson 
distribution, but this result is subsidiary to, and follows from, event 
independence. In this sense a better name than Poisson process is 
independent event process. 

In representing intensities of such processes, one scheme is to rep- 
resent each event as a delta-function in time. But a more convenient 
way to extract rate information incorporates the time intervals^ be- 
tween photons. Specifically, for each photon consider the interval 

7 A method for analyzing event data based solely on inter-event time intervals has been 
developed in ( [Prahl 1996] 1. 
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starting half way back to the previous photon and ending half way 
forward to the subsequent photon. This interval, namely 



(48) 



is the set of times closer to t n than to any other timejl and has 
length equal to the average of the two intervals connected by photon 
n, namely 

At n = tn+1 ~ tn ^ . (49) 



Then the reciprocal 

*n = ^~ (50) 

is taken as an estimate of the signal amplitude corresponding to 
observation n. When the photon rate is large, the corresponding 
intervals are small, demonstrates the data cell concept, including 
the simple modifications to account for variable exposure and for 
weighting by photon energy. 

|Prahl 1 996] has derived a statistic for event clustering in Poisson 
process data that tests departures from the known interval distri- 
bution by evaluating the likelihood over a restricted interval range. 
Prahl's statistic is 

Mn = ± E (1-7?). (51) 
where ATj is the interval between events % and i + and 

C * = ^H AT * (52) 

is the empirical mean interval. In other settings, the fact that this 
statistic is a global measure of departure of the distribution (used 
here only locally, over one block) may be useful in the detection of 
periodic, and other global, signals in event data. 



8 These intervals form the Voronoi tessellation of the total observation interval. See 
( |Okabe, Boo ts, Sugihara and Chiu 2000 ) for a full discussion of this construct, highly useful 
in spatial domains of 2, 3, or higher dimension; see also ( |Scargle 200lal |Scargle 2001c| ). 
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Height = n/dt 




Figure 12: Voronoi cell of a photon. Three successive photon detection times 
are circles on the time axis. The vertical dotted lines underneath delineate 
the time extent (dt) of the cell and the height of the rectangle - n/dt, where 
n is the number of photons at exactly the same time (almost always 1) - is 
the local estimate of the signal amplitude. If the exposure at this time is less 
than unity, the width of the rectangle shrinks in proportion, the area of the 
rectangle is preserved, so the height increases in inverse proportion yielding a 
larger estimate of the true event rate. 
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C Other Block Fitness Functions 



This appendix describes fitness function for a variety of data modes. 



C.l Event Data: Alternate Derivation 

The Cash statistics used to derive the fitness function in Eq. f[T9"j) is 
based on representation of event times as real numbers. Of course 
time is not measured with infinite precision, so it is interesting to 
note that a more realistic treatment yields the same formula. 

Typically the data systems' finest time resolution is represented 
as an elementary quantum of time, which will be called a tick since 
it is usually set by a computer clock. Measured values are expressed 
as integer multiples of it (cf. §2.2.1 of |Scargle 1998] ) . We assume 
that n m , the number of events (e.g. photons) detected in tick m 
obeys a Poisson distribution: 

(\dt) n ™ e~ Xdt _ A nm e- A 
L m — j — j , (53) 

Tl m . Tim, • 

where dt is the length of the tick. The event rates A and A are counts 
per second and per tick, respectively. Time here is given in units 
such as seconds, but a representation in terms of (dimensionless) 
integer multiples of dt is sometimes more convenient. 

Due to event independence the block likelihood is the product 
of these individual factors over all ticks in the block. Assuming all 
ticks have the same length dt this is: 

M(k) ( \rli\ n ™p- Xdt 

L (k) = TT { ~^4 , (54) 

m=l "w- 

where is the number of ticks in block k. Note that non-events 
are included via the factor e~ Xdt for each tick with n m = 0. When 
this expression is used to compute the likelihood for the whole in- 
terval (i.e. product of the block likelihoods over all blocks of the 
model) the denominator contributes the factor 

1 _ 1 

n n M(fc) « i ~~ n n ' ' ^ 

llfcllm n m ] - 11m ">m- 

where on the right-hand side the product is over all the ticks in the 
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whole interval. For low event rates where n m never exceeds 1, this 
quantity is unity. No matter what it is a constant, fixed once and for 
all given the data; in model comparison contexts it is independent 
of model parameters and hence irrelevant. Dropping it, noting that 
r£2 e" Adi is just e - XM(k)dt = e- XM(k) Collecting together all factors 
for ticks with the same number of events eq. f )54|) simplifies to 



DO 



L W =e -AM«-Q (Arft) n^)(n) ; (5g) 
n=0 

where H^ k \n) is the number of ticks in the block with n events. 
Noting that 

oo 

£n# w (n) = , (57) 

n=0 

where is the total number of events in block k, we have simply 

L« = {\dt) N(k) e~ XM(k) . (58) 

In order for the model to depend on only the parameters defining 
the block edges, we need to eliminate A from eq. (158]) . One way to 
do this is to find the maximum of this likelihood as a function of A, 
which is easily seen to be at A = -r^py, yielding 

^max ~ I M(fc) ) e l 0y J 
.. . , • ...... , fc = 

e~ N to the full model. Moving this ultimately irrelevant factor to 
the left-hand side, noting that = ^tt-, and taking the log, we 
have for the maximum-likelihood block fitness function 

log L$ ax + = N {k) ( \ogN {k) - logM (fc) ) . (60) 

equivalent to Eq. f fl9|) . 

An alternative way to eliminate A is to marginalize it as in the 
Bayesian formalism. That is, one specifies a prior probability distri- 
bution for the parameter and integrates the likelihood in Eq. ( 1581) 
times this prior. Since the current context is generic, not devoted 
to a specific application, we seek a distribution that expresses no 
particular prior knowledge for the value of A. It is well known that 
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there are several practical and philosophical issues connected with 
such so-called non-informative priors. Here we adopt this simple 
flat, normalized prior: 

P(\) = ^! — ^ — ^ 2 ((]]) 

otherwise ' 
where the normalization condition yields 

Thus eq. (|58|) . with A marginalized, is the posterior probability 

^ rg =P^f x X ;(\dt) NW e-^ k) d\ (63) 
= ^(^)^?^ ( V^ (64) 

where Z\p = T^Ai^- In terms of the incomplete gamma function 

7 (a,x) = [ z a - l e- z dz , (65) 
we have, utilizing M fc = 



o 



logP^rg = logg£ - iV«logM( fc ) + log[ 7 (A^) + 1, z 2 ) - 7 (jV« + 1, Zl ) 



(66) 

The infinite range z\ = 0, 22 = 00, gives 



log^irg(oo) = log w + logr(iV( fc ) + 1) - iV«logM« 



(67) 

This prior is unnormalized (and therefore sometimes regarded as 
improper). Technically p( A ) approaches zero as z 2 — > 00, but is 
retained here in order to formally retain the scale invariance to be 
discussed at the end of this section. 

Another commonly used prior is the so-called conjugate Poisson 
distribution 

P(A) = C A^V^ . (68) 
As noted by |Gelman, Carlin, Stern, and Rubin 1995 this "prior 
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density is, in some sense, equivalent to a total count of a-1 in (3 
prior observations," a relation that might be useful in some circum- 
stances. The normalization constant C = p^y, and with this prior 
the marginalized posterior probability distribution is 

P cp = C (°° x N(k) +^ e - xiM(k)+ ^dX , (69) 
J o 

yielding 

log P cp - log C = log T(N^ + a) - (N^ + a) log(M« + p) . 

(70) 

Note that for a = 1, j5 = 1 this prior and posterior reduce to those 
in Eqs. (28) and (29) of |Scargle 1998] . 

Equations ( 1T9"|) . (157]) and (1701) are all invariant under a 

change in the units of time. The case of eq. (167]) is slightly dodgy, as 
mentioned above, but otherwise is a direct result of expressing 
and as dimensionless counts, of events and time-ticks, respec- 
tively. (Further, in the case of eq. (166]) . z\ and are dimensionless.) 
As mentioned above, the simplicity of eq. ( 1191) recommends it in gen- 
eral, but specific prior information (e.g. as represented by eq. 155]) 
may suggest use of one of the other forms. 

C.2 0-1 Event Data: Duplicate Time Tags Forbidden 

In Mode 2 duplicate time tags are not allowed, the number of events 
detected at a given tick is or 1, and the corresponding tick likeli- 
hood is: 

L m = e - Xdt = l-p n m = (71) 
= 1 - e- Xdt =p n m = l (72) 

where A is the model event rate, in events per unit time. From the 
Poisson distribution p = 1 — e~ Xdt is the probability of an event, and 
1 — p — e~ Xdt that of no event. Note that p or A interchangeably 
specify the event rate. Since independent probabilities multiply, the 
block likelihood is the product of the tick likelihoods: 

L^= \{L m = p N(k \l-p) M{k) - N(k \ (73) 

m=l 
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where is the number of ticks in block k and is the number 
of events in the block. 

There are again two ways to proceed. The maximum of this 
likelihood occurs at p — and is 

r(fc) _ ( N(k) \N(v n N(k) AfW-jy(fc) (7A , 

^max ^][f(k)) V 1 M{k)> v'^J 

Using the logarithm of the maximum likelihood, 



log^L = A^logO + (M« - tf«)log(l - (75) 



yields the fitness function, additive over blocks. 

As in the previous sub-section, an alternative is to marginalize 

A: 

p(k) = J L (k)p^ dX 5 (76) 

where -P(A) is the prior probability distribution for the rate param- 
eter. With the flat prior in eq. ( jBT]0 the posterior, marginalized 
over A is 

P£Lg = p(A) /"'(I - e- Xdt f k (e- Xdt ) M(k) - Nk d\ • (77) 

Changing variables to p — 1 — e~ Xdt , with dp = dt e~ Xdt d\, this 
integral becomes 



PI 



with pi 2 = 1 — e Xl - 2dt ^ and expressible in terms of the incomplete 
beta function 

B(z; a, b) = f* u a '\l - uf^du (79) 
Jo 

as follows: 



logPrlfirg - log^ = hg[B(p 2 ; + 1, - iV«) - B( Pl ; + 1, M« - iV«)] 



(80) 



9 In jScargle 1998] we used p as the independent variable, and chose a prior flat (constant) 
as a function of p. Here, we use a prior fiat as a function of the rate parameter. 



G4 



The case p\ = 0,P2 = 1 yields the ordinary beta function: 



logPcSi 



differing from Eq. (21) of Scargle 1998 by one in the second argu- 
ment, due to the difference between a prior flat in p and one flat in 
A. All of the equations ([75} . (ISO]) , and ( 18~T|) . can be used as fitness 
functions in the global optimization algorithm and, as with Mode 1, 
are invariant to a change in the units of time. 



A brief aside: one might be tempted to use intervals between 
successive events instead of the actual times, since in some sense 
they express rate information more directly. However, as we now 
prove, the likelihood based on intervals is essentially equivalent to 
that in eq. f )58|) . It is a classic result |Papoulis 1965| that intervals 
between (time-ordered) consecutive independent events (occurring 
with a probability uniform in time, with a constant rate A) are 
exponentially distributed: 

P(dt)dt = Xe- Xdt U(dt)dt, (82) 

where U (x) is the unit step function: 

U(x) = 1 x > 
= x < . 

Pretend that the data consists of the inter-event intervals, and that 
one does not even know the absolute times. The likelihood of our 
constant-rate Poisson model for interval dt n > is 

L n = Xe- Xdt ", (83) 

so the block likelihood is 

L« = H\e- x *» = \ NW e- XMW , (84) 

n=l 

the same as in eq. (158|) . except that here is the number of 
inter-event intervals, one less than the number of events. 
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[Prahl 1996J derived a statistic for event clustering, by testing for 
significant departures from the known interval distribution, by eval- 
uating the likelihood over a restricted interval range. This statistic 
is 

M ^i£. (1 -f»' (85) 

where ATj is the interval between events T and i + 1, N is the 
number of terms in the sum, and 

<?* = ^£ A ^ (86) 

is the empirical mean of the relevant intervals. In some settings, the 
fact that this statistic is a global measure (as opposed to the local 
- over one block at a time - ones used here) may be useful in the 
detection of global signals, such as periodicities, in event data. 



C.3 Time-to-Spill Data 

As discussed in §2.2.3 of |Scargle 1998| , reduction of the necessary 
telemetry rate is sometimes accomplished by recording only the time 
of detection of every Sth photon, e.g. with S=64 for the BATSE 
time-to-spill mode. This data mode has the attractive feature that 
its time resolution is greater when the source is brighter (and pos- 
sibly more active, so that more time resolution is useful). With 
slightly revised notation the likelihood in Eq. (32) of |Scargle 1998 
simplifies to 

LP TS = A 5Af spiH e - AM(fc) (87) 

where AQ^j is the number of spill events in the block, and is 

as usual the length of the block in ticks. With iV = N^^S this is 
identical to the Poisson likelihood in Eq. (l54|) . and in particular the 

N {k) . n S 

maximum likelihood is at A = and the corresponding fitness 

function is 

logL^TTS ~ logiV = SN^ m [ log(N^S) - logM« ] (88) 
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just as in Eq. f|T9|) with = SN^^, and with the same property 
that the unit in which block lengths are expressed is irrelevant. 

C.4 Point measurements: Alternative Form 

An alternative form can be derived by inserting (1381) instead of fl36|) 
into the log of Eq. fl30|) as in §3.31 The result is: 



log^Kx = ~ E( ~ ^ WM f (89) 
Expanding the square gives 

log^L = -\\ E(^) 2 -2 E§)(E w)+(E w) a E 4 ] 

(90) 



- E(~2") [ E W nX 2 n -2(J2 W nX n ){J2 W n'^n') + (E W n ,a; n') 2 E W « i 

(91) 

= "J E(4")[ E^n - 2(E^) 2 + (E^n') 2 ] (92) 

= -nEWl E W « X n - (E^™) 2 ] ( 93 ) 

n.' ^n.' n n 



yielding 



where 



l0gL^ x = -|[En'(^)]^ 



(94) 



(7 



X 



E Wn^n - (E w nXnf (95) 



is the weighted average variance of the measured signal values in the 
block. It makes sense that the block fitness function is proportional 
to the negative of the variance: the best constant model for the 
block should have minimum variance. 
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C.5 Point measurements: Marginal Posterior, Flat Prior 

First, consider the simplest choice, the flat, unnormalizable prior 

P(X) = P* (for all values of A) , (96) 

giving equal weight to all values. The marginal posterior for block 
k is then, from Eq. (j3U|) . 



,/, o* ( 27F ) 



p = p* 



_1 (x n -X\2 



(97) 



Using the definitions introduced above in eqs. (13T1) . (|32|) . and ( 133]) 
we have 



P 



(2 
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-(a fe A 2 +6 fe A+c fc ) ^ 



(98) 



Using standard "completing the square," letting z = y/dk(X + ^-), 
giving 

z=a k (X + - — ) = a fc (A H h 



a k 4a( ' 



a k X 2 + b k X + c k + 



4:0,1 



and then using 



we have 



dz 



P 



*(2tt) 



7T (-pS-)-c k 

-e 4a fc 



From this result, the log-posterior fitness function is 



logP* - A k = log(P%/f) + 



C k 



where 



A, 



N k 



log(27r) - $>g(cr n ) 



-c k , 
(99) 

(100) 
(101) 

(102) 
(103) 



and the subscript refers to the fact that the marginal posterior was 
obtained with the unnormalized prior. The second and third terms 
in Eq. (11021 ) are invariant under the transformation fj42l . Further, 
since the integral of P(X) with respect to A must be dimensionless, 



(nS 



we have P* ~ j ~ -, so P* and ^Ja^ have the same a-dependence, 
yielding a formal invariance for f 1 1 2 j) . However the prior in eq. ( 196|) 
is not normalizable, so that technically P* is undefined. A way to 
make practical use of this formal invariance is simply to include a 
constant P* that has the proper dimension 



C.6 Point Measurements: Marginal Posterior, Normal- 
ized Flat Prior 

Marginalizing the likelihood in eq. (130 j) with the prior in eq. ( 16 ip . 
yields for the marginal posterior for block k: 



(27T) 

r = r v ' 

As before 



P fc = P^)^-^ [ X2 e-^J^f dX (104) 

lira ^ Ai 



pfc = p(A) ( 2?r ) 2 /" A2 e -(a fc A2+6 fc A + c fe ) rfA (1Q5) 

Now complete the square by letting z = y/ak(X + t*"), giving 



z 2 = a fc (A + -^) 2 = a fc (A 2 + ^ + f%) = a k X 2 + b k \ + ^ + c k - c k 
2a k a k Aa% Aa k 

(106) 

so we have 

pfe = P (A)W- e (^) r e -^A (lor) 



A6, 



Ilra^ra Jzi \f&k 

where 

21,2 = V^(Ai. 2 + (108) 



Finally, introducing the error function 

— f 

y/ft JO 



erf(ar) = -= [* e~*dt (109) 



we have 



pfc = p(A)v^ (2tt)- ; e (^- Cfc) ^ _ 

2 JOklln^n 
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Taking the log gives the final expression 



logPi -A k = MP< A \/J) + (£ - c) + W[ er H erf(Zl) 



(HI 

where the subscript A indicates the fact that this result is based on 
the finite-range prior in eq. f loTj) . Note that this fitness function is 
manifestly invariant under the transformation in eq. fj42|) . for the 
same reasons discussed at the end of the previous section, plus the 
invariance of 2^2. In the limits Z\ — > —00 and z 2 — > 00, erf(z 2 ) — 
erf(zi) — y 2, and we recover eq. (11021) - but remember that in this 
limit the invariance is only formal. 

C.7 Point Measurements: Marginal Posterior, Gaussian 
Prior 

Finally, consider using the following normalized Gaussian prior for 
A: 

P(A) = -= e~* { — ' (112) 

(Jov 2% 

corresponding to prior knowledge that roughly speaking A most 
likely lies in the range Xq ± uq, with a normal distribution. This 
prior is not to be confused with the Gaussian form for the likelihood 
in eq. ((29]). 

Eq. (!30|) . when A is marginalized with this prior, becomes 



1 r (27T)-(^) 1 f -|[A 2 (^+E„^)+M-^-^)+($+E„fl) 



so with 



(113) 

fl * = ^(i + Ei) ( 114 ) 



2Vg ' ^ a 2 n 



6* = -(^ + E§) ( 115 ) 



a n a n 



and 



* = 5(^+E^) aw) 

and eq. (|98|) is recovered, so that eq. (11021) . with the redefined coeffi- 
cients in eqs. (I114p . (I115p and (jll6j) . gives the final fitness function. 
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Any of the log fitness functions in eqs. (IMI) . (I102p . or f illip can 
be used for the point measurement data mode in this section. No 
general guidance for this depending on convenience or the kind of 
prior information for the signal parameters that makes sense. 

C.8 Data with Dispersed Measurements 

Throughout it has been presumed that two things are small com- 
pared to any relevant time scales: errors in the determination of 
times of events, and the intervals over which individual measure- 
ments are obtained as averages. These assumptions justify treat- 
ment of the corresponding data modes as points in §3. II and §3.31 re- 
spectively. Below are discussions of data that are dispersed because 
of (1) random errors in event times and (2) measurements that are 
summations or averages over non-negligible intervals. Binned data, 
an example of the latter, have already been treated in §3.21 and are 
not discussed here. 

A simple ad hoc way to deal with both of these situations is 
to compute kernel functions for each data point, representing the 
window or error distribution in either of the two above contexts. 
Each such function would be centered at the corresponding mea- 
sured value, evaluated at all of the data points, and normalized to 
represent unit intensity. Each such kernel would be maximum at 
the data point at which it is centered, but distribute some weight to 
the other data cells. The sum of all of these kernels would then be 
a set of weights at each measurement, which could then be treated 
as ordinary event data but with fractional rather than unit weights. 
The ad hoc aspect of this approach lies in the way the fitness func- 
tion is extended. The following sub-sections provide more rigorous 
analysis. 

C.8.1 Uncertain Event Locations 

Timing of events is always uncertain at some level. Here we treat the 
case where the error distribution is wide enough to make the point 
approximation inappropriate. Rare for photon time series, with mi- 
crosecond timing errors, this situation is more common in other 
contexts and with other independent variables. With overlapping 
error distributions even the order of events can be uncertain. In the 
context described in §1.41 one often wants to construct histograms 
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from measurements with errors - errors that may be different for 
each point (then called heteroscedastic errors). 

A simple modification of the fitness function described in §3.11 
addresses this kind of data. On the right-hand side of Eq. (JT9|) 
N^ k > quantifies the contribution of the individual events within block 
k. In extending the reasoning leading to this fitness function, the 
main issue concerns events with error distributions that have frac- 
tional overlap with the extent of block k - for events distributed 
entirely outside (inside) obviously contribute in no way (fully) to 
block fitness. By the law for the sum of probabilities of independent 
events, in the log-likelihood implicit in Eqs. f|T7|) and f lT8|) N^ k > is 
replaced by the sum of the areas under the probability distributions 
overlapping block fc, namely Y^iekP^ summed over all events with 
significant contribution to block k, and is the integral of the 
overlapping part of the error distribution, a fraction between and 
1. Thus we have 

logL (k \X) = logX^p® - AT (fc) (117) 
iefc 

in place of Eq. ([TO]) , with the analogous constant term on the left- 
hand side of that equation dropped. This result holds because a 
given datum falling inside and outside a block are mutually exclusive 
events. 

Implementing this relationship in the algorithm is easily accom- 
plished. For a given event and the interval assigned to it (cf. Figure 
in §B.5j) sum the overlap fractions with that interval of all events 



- including that event itself. These quantities could be approxi- 
mated with very simple or complex quadrature schemes, depending 
on the context and the way in which the relevant distributions are 
represented. Normally the array nn_vec, as in the code fragment in 
£ TA~1 is all l's (or counts of events with identical time-tags there are 
any); but here replace it with these summed event weights. This 
construction automatically assigns the correct fractional weights to 
the block with no further alteration of the algorithm. 

C.8.2 Measurements in Extended Windows 

This section discusses the case of distributed measurements in the 
sense that the time of measurement is either uncertain or is effec- 
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tively an interval rather than a point. (This is different from the 
use of this term in §3.31 to describe the distribution of the measure- 
ment error in the dependent variable.) Measurements may refer to a 
quantity averaged over a range of values of t, not at a single time as 
in §3231 EH ETUI and £13 In the context of histograms ( §H) 
the measured quantity becomes the independent variable, and the 
dependent variable is an indicator marking the presence of the mea- 
surement there. In both cases the measurement can be thought of 
as distributed over an interval, not just at a point. 

In this case the data cell array would be augmented by the in- 
clusion of a window function, indicating the variation of the instru- 
mental sensitivity: 

x = {x n ,t n , w n (t - t n )} n = l,2, ...,N, (118) 

where w n (t) describes, for the value reported as X n , the relative 
weights assigned to times near t n . 

This is a nontrivial complication if the window functions overlap, 
but can nevertheless be handled with the same technique. 

We assume the standard piece-wise constant model of the under- 
lying signal, that is, a set of contiguous blocks: 

B(x) = J2B {j) (x) (119) 
i=i 

where each block is represented boxcar function: 

B^(x) = { ? j X ~ (120) 

v ' L (J otherwise 

the Q are the change-points, satisfying 

min(x n ) < Ci < C2 < • • • Cj < Cj+i < ■ ■ ■ < Cn„ < max(x n ) (121) 

and the Bj are the heights of the blocks. 

The value of the observed quantity, y n , at x n , under this model 
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IS 



y n = J w n (x)B(x)dx 

= Ef=iJw n (x)B^(x)dx [LZZ) 
= EfliB,J^ +1 w n (x)dx 



so we can write 



where 



yn = Y. B PM) (123) 

3=1 

Gj(n) = / w n (x)dx (124) 

is the inner product of the n-th weight function with the support of 
the j-th block. The analysis in [Bretthorst 1988] shows how do deal 
with the non-orthogonality that is generally the case herein 

The averaging process in this data model induces dependence 
among the blocks. The likelihood, written as a product of likelihoods 
of the assumed independent data samples, is 

P(Data|Model) = Un=i P(y n \^ode\) (125) 

= nli ^=?e-2(— ) 126 

= itiU -fce-* ^ )2 (127) 

= Q e -3( 3 — ) , (128) 

where 

n 1 

q = n -7— • (129) 

n=i \ 2ir<J„ 



After more algebra and adopting a new notation, symbolized by 

^ ^ 2/n (130) 



10 If the weighting functions arc delta functions, it is easy to see that Gj(n) is non-zero if and 
only if x n lies in block j, and since the blocks do not overlap the product Gj(n)Gfc(n) is zero 
for j 7^ k, yielding orthogonality, '{ n )Gk( n ) = $j,k- And of course there can be some 

orthogonal blocks, for which there happens to be no "spill over", but these are exceptions. 
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and 

G k (n) „ , , , 
~V G fc M > 131 

we arrive at 

logP{{y n }\B) = Qe-% , (132) 

where 

N N b N N b N b N 

H = E Vl ~ 2 E s ; E ^(n) + EE E GAnMn) . 

n=l j=l n=l j=l k=l n=l 

(133) 

The last two equations are equivalent to Eqs. (3.2) and (3.3) of 
[Bretthorst 19 88], so that the orthogonalization of the basis func- 
tions and the final expressions follow exactly as in that reference. 



C.9 Piecewise Linear Model: Event Data 

Here we outline the computations of a fitness function for the piece- 
wise linear model in the case of event data. This means that the 
event rate for a block is assumed to be linear, as in Eq. (pQ). 

For convenience we take the fiducial time to be £2, the time 
at the end of the block. Take t\ to be the time at the beginning, so 
M = t 2 — ti is the length of the block, and the signal x is A(l — aM) 
at the beginning of the block and A at the end, and varies linearly 
in between. 

The block likelihood for the case of event data ij is 

L(A, a) = E M A(l + a(U - t 2 )) ]- A(l + a(t - t 2 ))dt (134) 

where the sum is over the N k events in the block and the integral is 
over the time interval covered by the block. Simplifying we have 

N k 

L(X, a) = N k \ogX + E M (1 + afc - t 2 )) } - A[(l - at 2 )t + -£ 2 ]^ 
i=i 1 

(135) 

L(X,a) = N k lo^A + E%[ (l + a(ti-t 2 )) ]-XM k (l-~M k ) (136) 
i=i 1 

Now let's compute the maximum likelihood as a function of A 
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and a, starting by setting 

f = f - M k (l - a -M k ) = (137) 
so that at the maximum of this likelihood we have 

A = M fc (l-W) (138) 



and therefore 



L(\ max , a) = N k \og[ ] + £ lo<?[ (1 + aft - i 2 )) ] - iV fc 

(139) 

r)T N Nk 

o-a = N * Xo9[ m^m ] + g M (1 + a{u ' h)) ] ~ Nk (140) 

BL* { t t 2 ) A 

iyJ^ + JL = (142) 

iV fc £t 1 + a(*i - t 2 ) (l-fM fc ) 1 ; 

f(a) = J-y (t »~ t2) + ^ (143) 

/W N k t l l + a(t t -t 2 ) + (l-§M fc ) (Mdj 

f ( a) = -J-f ^"^ ^- d44) 

/W iV fe [1 + aft - t 2 )Y (l-§M fc ) 2 1 J 

= -Af (146) 

(1-§M*) M fc ^l + aft-t 2 ) 1 J 



(1 - f M fc ) M fc 



^U=l l +a (U-t 2 ) 



(147) 



\- a -M k = --M k N k (f" {t \ h) J " 1 (148) 
2 2 ^l + a(^-t 2 y 
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^w k +N 4,TvAr (i49) 

C.10 Piecewise Exponential Model: Event Data 

In this case we model the signal as varying exponentially across the 
time interval contained in the block. Denoting the times beginning 
and ending the block as t\ and t 2 , and taking the latter as the fiducial 
time in Equation (jSJ), the signal is Xe~ aM at the beginning of the 
block and A at the end. 

Much as in §0.91 the block likelihood for the case of event data 
ti is the follow expression involving a sum over the Nk events in the 
block and an integral over the time interval covered by the block: 

N k r t 2 
L(X, a) = £ M Ae a(il -* 2) ] - / \e a{t ~ t2) dt (150) 
i=i Jtl 

L(X,a) = N k log\ + aY / (U-t 2 ) - A( ) (151) 

i a 

where M = t 2 — t\ is the length of the block. 

Now let's compute the maximum likelihood as a function of A 
and a: 

dL N k 1 - e- aM s , . 

a* = f-<— ^> (152) 

and therefore at the maximum we have 



r)T 

7T = - [N k (l-e- aM )- 1 ][(M + a- 1 )e- aM -a- 1 ] (154) 



^max(a) = iV fc log( - _ e _ aM ) + £ (tj - t 2 ) -- 



- e~ aM v a 



(155) 

Anas(a) = ^ M l _^* aM ) + aEfe- ^) -iV* (156) 
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BL (a) 1 - e~ aM 

^ L =^<hk- )Q+ ^ u - t ' ) (157) 

where 

Q = N k [(l - e'^Y 1 - a(l - e- aM )~ 2 Me~ aM ] (158) 

To solve for the value of a that makes this derivative zero (to find 
the maximum of the likelihood) we will use Newton's method to find 
the zeros of 

f(a) = dL ™^ /N k = - a - Me~ aM {l - e"^)" 1 + S (160) 
where 

S=^£fe-*2) (161) 

is the mean of the differences between the event times and the time 
at the end of the block. The iterative equation is 

f( a k) / 1(;o x 

a k+1 = «* " (162) 



and since S is a constant we have 
1 
a 



f (a) = -^-M[-Me- aM (l-e- aM Y l -Me~ aM {l-e- aM )- 2 e- aM } 



(163) 

/'(a) = -1 + MV aM (l - e-^-Hl + e" aM (l - e^)" 1 ] (164) 
and defining 

Q(a) = e- aM {l-e- aM )- 1 (165) 

we have 

f'(a) = -\ + M 2 Q{a)[l + Q(a)} (166) 

cr 

and 

a^ 1 - MQ(a k ) + S 
ttk+1 ~ ak ~ ~a k 2 + M*Q{a k )[l + Q{a k )]) (16?) 
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